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EDITORIAL 


KEMERDEKAAN DENGAN 
LINUX 


Hari kemerdekaan sebuah negara selalu diper- 
ingati tiap tahun, termasuk di Indonesia pada 
17 Agustus 2010 ini. Di era teknologi informasi, 
muncul pertanyaan: pentingkah kemerdekaan 
di bidang software atau program komputer? 
Sudahkah kita merasa merdeka ketika meng- 
gunakan komputer dan gadget lainnya? 

Dalam istilah FOSS (Free/Open Source 
Software), merdeka adalah kebebasan meng- 
gunakan program yang telah kita dapatkan 
secara berbayar maupun gratis. Pengguna juga 
memperoleh kebebasan untuk mempelajari cara 
kerjanya, lalu memodifikasinya, dan menyerbarluaskannya. Linux 
merupakan contoh produk berbasis FOSS yang dapat digunakan 
secara merdeka. 

Kebalikan dari merdeka adalah terikat. Terikat tidak berarti 
harus membayar lisensi yang mahal. Terikat dapat berarti menggu- 
nakan program secara tidak legal, sehingga dapat dihukum di dunia 
maupun di akhirat. Terikat juga dapat berbentuk ketergantungan 
kepada pembuatnya atau vendor tertentu saja sehingga jika ada 
masalah di kemudian hari, tidak ada pilihan lain kecuali meminta 
bantuan kepada vendor. Itu pun kalau vendornya masih ada. 

Kemerdekaan tidak selalu diartikan gratis atau tanpa biaya, 
kecuali tanpa biaya lisensi, karena biaya dapat muncul dari proses 
mendapatkan, menggunakan, mempelajari, mengembangkan atau 
memodifikasi, dan menyebarluaskan program. Dalam keadaan ter- 
tentu, pilihan untuk merdeka dapat memakan biaya lebih besar 
dibandingkan pilihan untuk terikat. Misalnya, Anda mengeluarkan 
biaya pelatihan menggunakan Linux yang nilainya bisa lebih besar 
dibandingkan menggunakan program terikat. 

Kemerdekaan bukan berarti bebas tanpa batas, sehingga 
melanggar kemerdekaan orang lain. Memilih Linux, apapun nama 
distronya, tetap memiliki keterbatasan, misalnya keharusan mengi- 
kuti ketentuan lisensinya. Salah satu contohnya, Fedora 13 meru- 
pakan produk yang sepenuhnya FOSS sehingga belum mendukung 
MP3. Sebagai solusinya, Anda dapat menambahkan program dari 
kumpulan paket Extras atau repository untuk mengatasi problem 
multimedia itu. Merdeka biasanya membutuhkan pengorbanan. m 
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Dua Kunci Sukses Grameen Bank 


open source di dunia bisnis terus 

berlanjut. Lanjutan kisah suk- 
ses kali ini datang dari salah satu 
lembaga keuangan mikro yang ter- 
dapat di Bangladesh, yakni Grameen 
Bank. Selidik punya selidik, ternyata 
kesuksesan tersebut mampu diraih 
lembaga keuangan ini lantaran dua 
faktor utama, yakni wanita dan open 
source. 

Seperti dikutip oleh detikINET 
usai workshop “Microfinance Busi- 
ness & Information Technology” 
yang digelar Sharing Vision di Royal 
Plaza, Singapura, Muhammad Shah- 
jahan, General Manager dan Chief 
Financial Officer Grameen Bank, me- 
nuturkan kalau hampir 97% dari na- 
sabah Grameen Bank yang totalnya 


ie sukses penggunaan aplikasi 


berjumlah 25 juta nasabah adalah 
kaum hawa. Menurut Shahjahan, 
kaum wanita itu berorientasi pada 
keluarga dan nilai-nilai kebaikan. 
Kaum wanita biasanya lebih mem- 
pertimbangkan keluarga dan anak- 
anaknya sebelum bertindak. 
Shahjahan juga menambahkan 
kalau wanita bertindak lebih ber- 
tanggung jawab dan lebih jujur 
karena sifatnya yang sangat mem- 
perhatikan keluarga. Berdasarkan 
pengalaman Grameen Bank, nasabah 
wanita mereka juga sangat taat me- 
matuhi cicilan kredit. Oleh kare- 
nanya, dari total pinjaman tingkat 
pengembaliannya mencapai 97,11%. 
Rasio kredit macet kurang dari 3%. 
Lebih lanjut, Shahjahan me- 
nambahkan kalau rahasia kesuk- 


AKTUAL 





Grameen Bank 


sesan Grameen Bank adalah pene- 
rapan teknologi informasi berbasis 
open source. Bangladesh bukan ne- 
gara kaya. Setengah penduduknya 
adalah rakyat miskin. Karenanya 
untuk infrastruktur TI, Grameen 
Bank menggunakan infrastruktur 
semurah-murahnya. Penggunaan ap- 
likasi open source merupakan pilihan 
terbaik untuk Grameen Bank. Salah 
satu aplikasi berbasis open source 
yang menjadi andalan Grameen 
Bank adalah MIFOS (Microfinance 
Opensource). 8i 


Membase 1.6.0 Betal 


Google Android 2.2 


Android telah meng- 

umumkan keterse- 
diaan rilis dari source 
code Google Android 2.2 
yang memiliki kode nama 
“Froyo”. Froyo merupa- 
kan rilis ketu- 
juh dari ri- 
lis Google 
Android 1.0, 
dan meru- 
pakan versi 
update terkini 


[< pengembang Google 





untuk sistem CI N ED = O | D 


operasi Google 
mobile. Dibandingkan 
dengan Google Android 
2.1, rilis terbaru ini telah 
menyertakan sejumlah pe- 
rubahan, peningkatan, dan 
penyertaan fitur terbaru. 
Pada Google Android 
2.2 telah disertakan se- 
jumlah API dan layanan 
terbaru, seperti fungsi 
API baru untuk melaku- 
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i I 2.2 ini 
menyertakan 


kan proses back up dan 
restore data, dan sebuah 
compiler JIT Dalvik baru 
yang dapat meningkatkan 
kinerja kode CPU secara 
keseluruhan hingga men- 
capai dua hingga lima kali 
dibandingkan 
dengan An- 

droid 2.1. 
Android 


juga 


dukungan un- 
tuk kalangan 
enterprise, se- 
perti sinkronisasi kalendar 
dan pencarian otomatis 
account Exchange, serta 
fitur penghapusan daftar 
alamat yang dapat dilaku- 
kan secara remote. Infor- 
masi lebih lanjut seputar 
Android 2.2 dapat ditemu- 
kan pada url http://devel- 
oper.android.com/sdk/an- 
droid-2.2.html.m 


web infrastruktur yang 

belum lama beropera- 
si, bersama dengan Zynga, 
perusahaan game  sosial, 
dan NHN, perusahaan 
pembuat game dan search 
engine dari Korea Selatan, 
telah merilis Membase, da- 
tabase open source baru 
untuk NoSQL. Membase 
dirancang untuk aplikasi- 
aplikasi web dan dibuat 
berdasarkan memcache, 
yakni sistem cache yang 
tersimpan dalam memory. 

Membase  menambah- 
kan kemampuan berbasis 
disk-memcached, bersama 
denganmanajemenpenyim- 
panan hierarki, replikasi 
data, dan dukungan pe- 
nyimpanan yang aman. 
NorthScale, yang didiri- 
kan oleh para pengembang 
proyek memcached, telah 
mengumumkan kalau versi 


N orthScale, perusahaan 


Jf MEMBASE.ORG 


beta dari versi enterprise 
komersial dari versi Mem- 
base Server juga telah 
tersedia, yang tergabung 
dengan layanan komersial 
server Memcached yang 
telah ada. 

NorthScale menjelaskan 
kalau mereka ingin men- 
ciptakan solusi manajemen 
data elastis dengan latency 
rendah, cepat dan seder- 
hana, mudah dikelola, 
memiliki throughput, dan 
rekonfigurasi cluster yang 
dinamis. Proyek ini juga 
bersifat open source, dan 
berlokasi di situs mem- 
base.org. Pada situs ini, 
pengembang dapat mene- 
mukan informasi dimana 
memperoleh versi source 
dan binari untuk kode 
Membase 1.6.0 Beta 1.m 
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AKTUAL 
91 Persen SuperGomputer Top-500 Gunakan Linux 


6 


berbagai macam jenis hardware. 

Khusus untuk SuperComputer, 
pada awal Juni 2010, Top500 kemba- 
li memperbarui daftar rangking dari 
500 SuperComputer tercepat dunia. 
Dari daftar Top500 SuperComputer, 
tercatat sebanyak 455 atau 91 persen 
SuperComputer yang beroperasi 
menggunakan sistem operasi meng- 
gunakan kernel Linux. 

Jauh di belakang Linux, sebagai 
nomor dua terhitung sistem operasi 
UNIX dari semua jenis yang mengan- 
tongi porsi 4.4 persen, sisanya adalah 
gabungan dari aneka sistem operasi 
lainnya yang digunakan oleh 3.4 
persen SuperComputer terdaftar di 
Top500. Sistem operasi besutan Mic- 


Ke... Linux sudah teruji di 


Distro Hemat Energi 


hemat penggunaan daya 


rosoft (Windows) masih sempat di- 
gandrungi 5 SuperComputer dengan 
kuota 1 persen dan mampu bercokol 
di posisi nomor 4. 

Seperti ajang Formula 1, para in- 
sinyur ahli komputer saling berkom- 
petisi dalam menciptakan komputer 
tercepat dunia. Jawara komputer 
tercepat dunia kali ini masih tetap 
disandang oleh SuperComputer ber- 
basis Linux: Cray Jaguar, yang ter- 
pasang di Oak Ridge National Labo- 
ratory dengan kinerja maksimal 
sebesar 1759 TFlops. Posisi nomor 
dua adalah pendatang baru Cina 
dengan sistem Nebulae kinerja Com- 
puting Power sebesar 1271 TFlops. 

Andaikan yang diukur adalah 
Peak Power maka posisi menjadi 


end Technologies, kon- 





terbalik, dimana Nebulae dari Cina 
dengan 2984,3 TFlops memecahkan 
rekor dunia sebagai nomor satu, se- 
dangkan Jaguar dengan 2331 TFlops 
tergeser ke posisi nomor dua. Po- 
sisi ketiga diduduki oleh Roadrun- 
ner dari DOE/NNSA/LANL di Los 
Alamos, yang sebelumnya terdaftar 
sebagai nomor dua dengan kinerja 
maksimal sebesar 1042 TFlops dan 
peak sebesar 1375 TFlops.m 


Zend Cluster Manager 


kapi dengan fitur untuk 


engembang wattOS 
prs: mengumumkan 

rilisterbarudistromere- 
ka, yakni wattOS R2. Dari 
penjelasan yang terdapat 
pada situsnya,  wattOS 
berfokus pada penggunaan 
daya listrik yang rendah, 
dan dapat dioperasikan 
pada spesifikasi hardware 





listrik dalam kegiatan 
berkomputerisasi sehari- 
hari. Menurut penjelasan 
yang diberikan, update 
terbaru dari wattOS juga 
memiliki waktu boot dan 
proses instalasi yang lebih 
cepat, kecepatan aplikasi 
secara keseluruhan juga 


yang rendah. Un- lebih meningkat. 
tuk memenuhi Sejumlah pe- 
. ` ty | D 

persyaratan ini, | ae rubahan lain 
wattOS meng- _ b = yang terdapat 
gunakan desktop pa pada wattOS 
yang berbasiskan R2, di antaranya 
pada Openbox penggantian ap- 
dan LXDE. HOS likasi pemutar 

Rilis terbaru w musik dari Exaile 


dari wattOS R2 berbasis- 
kan pada Ubuntu 10.04 
LTS “Lucid Lynx” dan 
telah menyertakan fitur 
manajemen daya listrik, 
yang bertujuan untuk 
membantu para pengguna 
untuk dapat lebih meng- 
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menjadi Rhythmbox, dan 
penambahan aplikasi F- 
Spot. Jika ingin menik- 
mati desktop wattOS R2, 
Anda dapat menemukan 
file iso distro wattOS R2 
pada ekstra DVD InfoLI- 
NUX edisi ini. m 


[7 utama untuk 
pengembangan PHP, 
telahmengumumkanketer- 
sediaan rilis Zend Server 
Cluster Manager. Paket 
aplikasi ini dapat mem- 
perluas fungsi Zend Server 
dalam pengembangan ber- 
basis bahasa PHP yang 
memiliki skala besar. 


Menurut keterangan 
dari pihak 
Zend, Zend 
Server Cluster 





Manager mem- 
permudah para 
penguna dalam kemudah- 
an melakukan monitoring 
dan memanajemen bebera- 
pa aplikasi Zend Server, 
untuk memastikan keter- 
sediaan yang tinggi dari 
aplikasi, dan meningkat- 
kan skalabilitas aplikasi. 
Zend Server Cluster 
Manager juga  dileng- 


Zend 


The php Company pengembangan 


sesi cluster, monitor dan 
manajemen konfigurasi 
yang terpusat, dan ad- 
ministrasi konsol berbasis 
konfigurasi web. 

Eldad Maniv, Zend VP 
of Product and Market- 
ing, menjelaskan kalau 
Zend Server Cluster Mana- 
ger merespons kebutuhan 
yang dibutuhkan oleh 
banyak penggu- 
na, yang ingin 
menjalankan 


aplikasi PHP 
skala besar untuk peng- 
guna rumahan atau proyek 
berbasis PHP lainnya, 
seperti Drupal, Magento, 
Joomla!, dan SugarCRM. 
Zend Server Cluster Mana- 
ger, sudah dapat di-down- 
load dari url: http://www. 
zend.com/en/products/ 
server-cluster-manager/. m 
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| Made Wiryana 


Kunci Mengunci 


Ekosistem 


aat ini, dalam bisnis perangkat 
lunak, seringkali alasan meng- 
gunakan perangkat lunak ter- 
tentu, bukan saja fitur, harga, 
atau dukungan/jaminan vendor dari 
perangkat lunak tersebut, 
lebih karena kondisi ekosistem dari 
sistem perangkat lunak/keras ter- 


tetapi 


MMA Lu . 
NS sebut dari perangkat pengembang 
NA perangkat lunak, vendor penyedia 


melingkupi atau mengikat ekosistem tersebut. 


Semakin besar ekosistem maka 
para vendor atau pengguna akan 
semakin tertarik untuk bergabung. 
Tetapi ukuran ekosistem pada saat 
itu saja tidaklah cukup. Yang perlu 
diperhatikan adalah "tren" dari 
penambahan ekosistem. Sebab 
biasanya para developer tentu 
lebih tertarik melihat kepada masa 
depan, bukan kondisi saat ini. 
Suatu ekosistem yang baik 
memiliki tren penambahan ekosis- 
tem yang besar. 

Hal itulah yang menyebabkan 
kini banyak developer beralih ke 
Android karena melihat penamba- 
han  ekosistemnya yang melaju 
sangat kencang. Walau mungkin 
jumlah ekosistemnya belum me- 
nyamai yang lain. Itu jugalah yang 
membuat developer tidak tertarik 
lagi dengan Windows Mobile untuk 
perangkat smartphone karena 
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melihat tren penambahannya yang 

lambat sekali atau bahkan 

cenderung seperti menghilang. 
Penambahan ekosistem ini sen- 


para developer untuk bergabung ke 
dalam ekosistem yang dibuatnya. 
Akan tetapi, seringkali juga ke- 
diktatoran vendor dalam  me- 
nentukan siapa yang boleh ber- 
gabung dalam ekosistem dan 
menentukan arah ekosistem ter- 
sebut menjadi faktor pendorong, 
yang menyebabkan banyak deve- 
loper hengkang dari ekosistem ter- 
sebut dan pindah ke ekosistem lain. 
Hal ini terjadi pada beberapa 
developer yang sudah 
meninggalkan platform iPhone 
karena merasa  terkekang, lalu 
berpindah ke platform open source. 
Open source menjadikan para 
developer memiliki posisi yang 
setara dengan para vendor. 
Perubahan pola market perang- 
kat lunak ini mengindikasikan 
open source memiliki nilai lebih di 
dalam pembentukan ekosistem. 
Sebagai contoh Android yang 
relatif bebas, memiliki ekosistem 
yang tumbuh pesat. Siapa saja bisa 
mengembangkan dan bergabung, 
tanpa legitimasi yang formal. 
Ekosistem yang dibentuk oleh open 
source memiliki survivability yang 
lebih tinggi, karena tidak 
bergantung kepada apapun. 
Kondisi perubahan posisi deve- 
loper dalam ekosistem saat ini me- 
nguntungkan negara seperti Indo- 
nesia, karena memiliki bargaining 


Open source menjadikan para 
developer memiliki posisi yang setara 
dengan para vendor.,, 


diri, bukan saja bergantung pada 
fitur yang ada pada sistem ter- 
sebut, tetapi juga sangat ditentu- 
kan pada mudah/tidaknya seo- 
rang developer memulai pengem- 
bangan. Sulit atau tidaknya ini di- 
tentukan oleh kondisi lisensi, dan 
juga ketersediaan dokumentasi. 
Tentu saja berbagai vendor ber- 
usaha mencoba menarik hati 


position lebih tinggi di mata ven- 
dor dikarenakan jumlah pengguna 
yang besar di Indonesia. Sayang- 
nya, kondisi ini jarang diman- 
faatkan oleh developer mau- pun 
lembaga pendidikan di Indonesia 
untuk tawar-menawar dengan 
vendor agar diberi akses pada 
pengetahuan untuk mengembang- 
kan perangkat lunak. E 


www.infolinux.web.id 
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bertambahnya 
Sampah Digital 





aru saja saya membeli hard 
disk 
Tera Byte atau 1.000 GB. Luar 
biasa. Beberapa tahun 
lalu tidak terbayang kalau 
akan memiliki harddisk sebesar itu. 
Artinya, 
| sudah sebanyak itu. Lebih hebat 
lagi, anak saya juga minta dibelikan 
harddisk yang sama. Berapa banyak 
data yang dia hasilkan, kalau nanti 


eksternal sebesar satu 


yang 
saya 


data yang saya miliki 


sudah seumuran dengan saya? 


Saya coba cermati, apa yang ada di 
dalam harddisk saya. Ternyata doku- 
men yang berbentuk tulisan atau 
spreadsheet tidak berjumlah banyak. 
Yang banyak adalah berkas musik, 
foto, video, dan backup program. Un- 
tuk anak saya ada tambahan lagi, 
yaitu berkas program permainan 
atau games. Artinya, data yang saya 
hasilkan sebagian besar bukan untuk 
pekerjaan, tetapi untuk entertain- 
ment. Hadoh! 

Saya perkirakan sebagian besar 
kawan-kawan saya juga mengalami 
hal yang sama, yakni kehabisan 
ruang harddisk. Pola penggunaan- 
nya saya duga hampir sama juga. 

Dugaan saya, laju penambahan 
data digital ini akan tetap atau ma- 
lah bertambah. Hal ini disebabkan 
oleh adanya kebiasaan baru orang 
Indonesia yang didukung oleh keter- 
sediaan teknologi. Mendengarkan 
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lagu digital sudah bukan hal yang 
asing lagi bagi sebagian besar kita, 
apalagi bagi remaja. Hampir semua 
remaja yang saya tahu men- 
dengarkan lagu dengan format mp3. 
Demikian pula kamera digital su- 
dah murah harganya sehingga ora- 
ng tidak berpikir panjang untuk 
mengambil foto. Kalau kita 


Berkas-berkas yang dihasilkan 
ini, musik dan foto, tidak semua- 


nya sering digunakan. Berapa 
banyak sih lagu yang bisa kita de- 
ngarkan dalam sehari? 
Sementara itu, berapa banyak 


lagu mp3 yang kita koleksi? 
Demikian pula seberapa sering 
kita melihat atau menggunakan 
foto yang kita simpan? Rasanya 
tidak banyak. 

Untuk kasus foto, situasinya le- 
bih parah lagi. Kita mengambil foto 
beberapa kali untuk satu kejadian. 
Mungkin hanya satu foto yang kita 
gunakan atau kita sukai, selebih- 
nya tidak kita gunakan, tetapi 
tetap kita simpan. Kalau dulu, kita 
lebih berhati-hati dalam memotret 
karena ada biaya untuk mencetak 
foto dan juga kita harus menyedia- 
kan tempat (album) untuk menyim- 
pan foto-foto tersebut. Kita lebih 
selektif dalam memotret. Sekarang, 
tidak lagi. 

Berkas-berkas yang jarang kita 
gunakan ini sebetulnya merupakan 
sampah. Sampah digital. Saat ini, 
mungkin Anda belum melihatnya 
sebagai masalah, tetapi yang 
namanya sampah semestinya 
merupakan masalah, ya? Mungkin 
karena jumlah data yang Anda 
miliki relatif “masih sedikit” dan 
masih dapat ditampung dalam disk 
yang dimiliki, Anda tidak 
merasakan ini menjadi masalah. 
Anak muda saat ini masih tenang- 
tenang saja. Tunggu saja nanti. 

Bagi yang datanya sudah ter- 
lalu banyak, seperti saya, hal ini 


T 
Artinya data yang saya hasilkan 
sebagian besar bukan untuk pekerjaan 
tetapi untuk entertainment., 


perhatikan, sebagian besar 
handphone pun sudah memiliki 
kamera. Artinya, semakin mudah 
orang memotret dan menyimpannya 
dalam berkas digital. 


sudah merupakan masalah besar. 
Hanya saja, saya masih menutup 
mata dan lari dari kenyataan. 
Saya masih tetap membuat sampah 
digital. Tolooonnnggg...! M 


www. .infolinux.web.id 
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24 Hours Help Desk 
and Technical Support 
021-5269311 
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Demam Android 





netbook menjadi murah. 


Android yang dikembangkan oleh 
Android Inc. dan kemudian dibeli 
oleh Google ini menggabungkan Li- 
nux kernel yang sudah dimodifikasi 
dengan middleware dan aplikasi lang- 
sung untuk ponsel melalui bahasa 
pemrograman Java. 

Pada 5 November 2007, Android 
berhasil masuk ke Open Handset 
Alliance yang terdiri atas 71 
perusahaan TIK dan membuat 
standar terbuka untuk ponsel. 
Beberapa jenis handset Android 
dijual dengan harga lumayan mahal. 

Maret 2009, beberapa perusa- 
haan besar di Jepang mendirikan 
Open Embedded Software Foun- 
dation untuk menggunakan And- 
roid sebagai bagian dari embed- 
ded system dan menentukan stan- 
dar umum, pengembangan ber- 
sama, dan mempromosikan sistem 
operasi Android. Saat ini, anggota 
OESF sekitar 84 perusahaan yang 
terdiri dari negara Jepang, Cina, 
Taiwan, Korea, India, Amerika, 
Kanada dan Vietnam. 
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oogle membuat kejutan dengan 
memperkenalkan Android un- 
tuk ponsel, menyaingi iPhone 
dan Windows 
sudah berjaya sejak awal tahun 
2000-an. Dalam perjalanannya, ban- 
yak perusahaan produsen komputer 
dan gadget 
gunaan Android di berbagai peranti. 
Bahkan ada usaha untuk menjalan- 
kannya di netbook, sehingga harga 


Mobile yang 


menyepakati peng- 


Di Jepang, sebetulnya sudah 
ada satu standar untuk industri 
TIK, yaitu TRON yang dibuat 
oleh Professor Ken Sakamura dari 
University of Tokyo pada 1985, 
dalam bentuk peranti pen peng- 
gerak kursor yang dapat langsung 


elektronik dan komputer Jepang, 
seperti Fujitsu, NTT, NEC, Hitachi, 
dan Omron. Beberapa perusahaan 
di luar Jepang juga mengikuti 
standar TRON. 

TRON seolah-olah sudah men- 
jadi standar embedded peranti elek- 
tronik dan TIK dunia, dan dapat 
kita rasakan manfaatnya dalam 


berbagai bentuk, seperti remote 
control televisi dan AC, peranti 
elektronik pengendali mesin 


minuman, dan peranti kecil atau 
gadget lain yang banyak dipakai. 
Mulai 2010 ini, sepertinya peran 
TRON segera akan digantikan oleh 
Android yang dalam berbagai hal 
mempunyai keunggulan, termasuk 
mendukung gerakan open source 
yang sudah banyak dikenal. 

Jepang yang merupakan negara 
industri kelas dunia memang san- 
gat membutuhkan pengembangan 
sistem operasi embedded seperti 
ini, karena semua mesin dikem- 
bangkan dengan teknologi tinggi, 
tetapi harus dengan biaya yang 
relatif murah. Cina dan Taiwan 
merupakan pesaing ketat industri 
elektronik dan TIK Jepang, yang 
sudah memulai industrinya dari 
tahun tujuh puluhan, 
mengalahkan Amerika dan Eropa 
yang tidak bisa efisien dalam 
proses. 


T 
. Android yang dalam berbagai hal 
punya keunggulan, termasuk mendukung 
gerakan open source...,, 


terlihat di layar, yang saat ini di- 
gunakan oleh peranti komputer, 
terutama notebook sebagai alat 
penunjuk berbentuk track ball 
atau digitizing pen. 

Peran TRON dalam mengubah 
industri elektronik dan TIK di 
Jepang sangat besar. Ada lebih 
dari 280 anggota yang masuk ke 
dalamnya, yang sebagian 
merupakan perusahaan raksasa 


Sebetulnya, kita dapat ikut ber- 
peran serta dalam kancah TIK 
dunia melalui Android. Terutama 
dengan mengembangkan peranti- 
peranti keras yang dibuat di 
Taiwan atau Cina dan mengem- 
bangkan peranti lunak aplikasinya 
di Indonesia, sehingga dapat men- 
jadi produk unggulan dan di masa 
depan dapat memulai produksi 
peranti keras dengan lebih baik. M 


www.infolinux.web.id 
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SURAT ANDA 





Punya opini, pendapat, kritik, atau saran yang terpendam untuk InfoLINUX? 






Sampaikan melalui surat ke Redaksi InfoLINUX, Jl. Kramat IV No. 11, Jakarta, 10430 


Distro Asli Indonesia 

1. Untuk InfoLINUX edisi men- 
datang, mohon disertakan file iso 
distro asli buatan Indonesia dalam 
ekstra DVD InfoLINUX. 

2. Mohon disertakan penjelasan dari 
masing-masing distro yang diserta- 
kan dalam ekstra DVD Info- 
LINUX. Sebagai pembaca baru 
InfoLINUX dan karena status saya 
masih pelajar SMP, terkadang 
saya masih merasa kesulitan 
dengan distro-distro tersebut. 
Karena terkadang, dalam majalah 
tidak disertakan penjelasan 
mengenai distro bersangkutan 
sehingga saya agak kesulitan 
memahaminya. 

Sendy Brammadi - via e-mail 


1. Ok. Akan kami pertimbangkan 
dahulu, apabila hal ini memang 
menarik untuk kami penuhi. 

2. Terima kasih atas masukannya. 
Mulai edisi ini, InfoLINUX sudah 
menyertakan file README- 
FIRST.txt pada setiap direktori 
DISTRO yang disertakan dalam 
ekstra DVD |. InfoLINUX, file 
tersebut berisikan alamat website 
distro bersangkutan dan sejumlah 
link yang dapat membantu Anda 
dalam memperoleh informasi lebih 
lanjut mengenai distro 
bersangkutan. 


Artikel Mengenai VLAN 


Pada edisi mendatang, tolong diser- 
takan artikel tentang konfigurasi 
VLAN di Linux. Kalau bisa mulai 
dari dasar-dasarnya, hingga proses 
konfigurasi tingkat lanjut. Menurut 
saya, artikel tersebut dapat mem- 
bantu kami para newbie dalam 
menghemat biaya pembelian hard- 
ware seperti switch manage. 

Noname - via e-mail 


14 08/2010 m INFOLINUX 


atau e-mail di Redaksi@Infolinux.co.id. 


Terima kasih atas usulannya yang 
menarik. Jika memang memungkin- 
kan, InfoLINUX akan coba memuat 
artikel mengenai VLAN pada salah 
satu artikel InfoLINUX edisi men- 
datang. 


Tutorial Distro Debian 

1. Apakah apt-get dapat digunakan 
untuk menginstalasi program dari 
paket source code (tar.bz/tar.gz)? 
Kalau bisa, bagaimana cara mela- 
kukan hal tersebut? 

2. Apakah ada aplikasi yang dapat 
digunakan untuk mengubah paket 
tarball menjadi paket binari, atau 
dari paket binari menjadi paket 
binari lainnya? 

3. Di mana saya dapat memper- 
dalam ilmu tentang distro 
Debian di Internet, tapi 
menggunakan bahasa Indonesia? 
Karena kebanyakan tutorial De- 
bian yang saya temukan di Inter- 
net masih berbahasa Inggris. 

Akuy - via e-mail 


1. Apt-get tidak dapat digunakan 
untuk menginstalasikan paket 
yang masih berformat tarball/- 
source code. Namun, tool ini da- 
pat digunakan untuk membantu 
dalam membuat suatu paket 
tarball/source code menjadi pa- 
ket binary. Untuk mengetahui 
lebih lanjut mengenai hal ini, da- 
pat dilihat pada url http://www.- 
debian.org/doc/manuals/apt-howto 
/ch-sourcehandling.en.html. 

2. Untuk mempermudah proses peng- 
ubahan suatu paket tarball men- 
jadi paket binari, Anda dapat 
menggunakan aplikasi checkins- 
tall — (http://www.asic-linux.com.- 
mx/~izto/checkinstall/). Tool ini 
dapat mengubah paket tarball 
menjadi paket binari dalam format 





deb, rpm, atau tgz. Sedangkan un- 
tuk mengubah suatu format paket 
binari menjadi format paket binari 
lainnya, Anda dapat mengguna- 
kan tool Alien (http://linux.die- 
.net/man/1/alien). 

3. Meski ada, namun saat ini masih 
jarang dokumentasi Debian 
dalam bahasa Indonesia. Jika 
membutuhkan dokumentasi 
distro Debian yang lengkap, 
Anda dapat membuka halaman 
dokumentasi Debian di url 
http://www.debian.org/doc/. 
Alternatif lainnya, Anda dapat 
membaca buku mini InfoLINUX 
yang berjudul Panduan Praktis 
Debian GNU/Linux 3.1 terbitan 
PT. Dian Rakyat, yang dapat 
dipesan melalui Prima DR, via 
e-mail: pesan@primabuku.co.id, 
atau phone: (021) 3190-4075. 


Reguest Ubuntu UE 
Sudah 4 tahun saya langganan 
InfoLINUX, tapi kenapa Info- 
LINUX belum pernah memberikan 
distro Ubuntu Ultimate Edition? 
Untuk men-download sendiri juga 
tidak memungkinkan bagi saya, 
karena ukuran file iso Ubuntu UE 
cukup besar. Untuk itu, saya 
berharap InfoLINUX dapat mem- 
berikan bonus Ubuntu Ultimate 
Edition versi terbaru pada salah 
satu ekstra DVD InfoLINUX edisi 
mendatang. 

Rajib Suraja - via e-mail 


Terima kasih atas | usulannya. 
Terkait banyaknya distro besar lain 
yang dirilis dalam waktu dekat, 
maka kami tetap harus selektif 
dalam menentukan isi ekstra DVD 


InfoLINUX. Meski demikian, 
usulan Anda tetap akan kami 
pertimbangkan. 


www.infolinux.web.id 





Barr 


Presentasi Utama 
"Peta Jalan BlankOn" 


Rahman Yusri Aftian, Wiraswasta, Gresik 


"Pengembangan Bisnis BlankOn 
melalui Koperasi" 


Endy Chandra, Software Architect, Bandung 


"Bentuk-bentuk Kerjasama Bisnis BlankOn" 


Rusmanto Maryanto, Penulis Senior, Jakarta 


"Implementasi BlankOn pada 
usaha mikro kecil dan menengah" 
Ahmad Haris, Staf Teknis TI, Banda Aceh 


"BlankOn sebagai sebuah gerakan 
Open Source" | 


Akhmat Safrudin, Senior Hacker BlankOn, 


Jakarta 


Tutorial 
"Membuat Server Game Urban Terror" 
Arman Satari, OSS Implementor, Makassar 
"Instalasi server LTSP " 
Putu Wiramaswara Widya, Pelajar, Bali 


"Instalasi dan Penggunaan 
Sistem Informasi Akademik" 
Muhidin Saimin, Guru, Depok 


"Membuat Paket Debian yang Bersih 
dengan Pbuilder" 
Iwan Setiawan, 
Linux System and FOSS Engineer, Bandung 


"Membangun Custom Kernel" 
Dwi Sasongko Supriyadi 
Pengembang Kernel, Magelang 
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Universitas Surabaya 
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Presentasi & Diskusi 


"Penggunaan Linux BlankOn di SMKN 1 Bima" 
M. Olan Wardiansyah, Guru, Bima 
"Tantangan dan Peluang Implementasi 
Migrasi di Sektor Pemerintah" 
Didiet Agus Pambudiono, 
Software Developer, Surabaya 
"Linux BlankOn untuk Penulisan Ilmiah" 
Boyke Soebhali, Urologist, Samarinda 
"Pemasaran Linux BlankOn" 
Utian Ayuba, Network Engineer, Bogor 
"Teknologi Server Terkini" 
Nurman Hadi, Rainer Customer 
Relation Manager, Jakarta 
Umum : Rp 100.000 
Pelajar/Mahasiswa : Rp 50.000 
Pendaftaran & Informasi: 
Jakarta : Surabaya : 
Fanida Ismaini Adi Setiawan 
021 6877 4847 0817 2714 14 
Situs : http://konf.blankonlinux.or.id 
E-mail : konf@blankonlinux.or.id 
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Kolaborasi 


ernah membuka situs Wikipedia? 
Jika pernah, Anda pasti akan mera- 
sa kagum akan kelengkapan infor- 
masi yang terdapat dalam situs ini. 
Semua informasi yang terdapat dalam 
situs Wikipedia tersedia secara free, dan 
siapa saja dapat turut berkontribusi. 
Hebatnya lagi, aplikasi yang digunakan 
oleh Wikipedia adalah MediaWiki, yang 
juga bersifat free dan open source. 
MediaWiki adalah aplikasi wiki ber- 
basis web bersifat free yang dibuat oleh 
Wikimedia Foundation. MediaWiki 
ditulis menggunakan script PHP dan 
menggunakan sebuah database untuk 
penyimpanan datanya. Pada tahun 2009, 
tercatat lebih dari 2.000 situs wiki yang 
menggunakan MediaWiki. Untuk me- 
nambah fungsionalitas MediaWiki, pada 
situsnya juga sudah tersedia lebih dari 
1.500 extensions yang dapat digunakan. 
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via WIKI 














Bagi pembaca yang ingin menggu- 
nakan MediaWiki, rubrik Utama kali 
ini membahas cara membuat web wiki 
menggunakan MediaWiki. Beragam 
hal yang berkenaan dengan MediWiki 
dijelaskan dalam artikel ini, mulai dari 
petunjuk instalasi, pengaturan admin, 
pembuatan user, pengeditan halaman 
main page, menambahkan skin/themes, 
hingga cara menambahkan ekstensi. 

Selain rubrik Utama, ekstra DVD 
InfoLINUX kali ini menyertakan bonus 
Fedora 13 plus sejumlah paket ekstras. 
Dengan ini, Anda dapat menikmati file 
multimedia di desktop Fedora 13. Distro 
lain yang disertakan adalah @imo 4 Kids 
2.0 dan NexentaStor Community 3.0.3. 
Pembahasan kedua distro ini juga dapat 
Anda temukan dalam rubrik Workshop 
Distro dan Praktik Instan edisi ini. m 

Supriyanto [supriyanto@infolinux.co.id] 
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Fedora 13 17 
Qimo 4 Kids 2.0 17 
Game 

Lugaru HD 0.0.0.0 Rev269 18 
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Hardware 

Blender Studio Projects: 19 


Digital Movie-Making 

Official Ubuntu Server Book, 19 
The (2nd Edition) 

The Definitive Guide to 19 
Samba 4 (v. 4) 

[Paperback] 


Definisi Label “On the Disc” 


Sebuah software yang 
memperoleh label “On 
the Disc”, berarti Anda 
dapat menemukan paket 
software tersebut dalam 
bonus Disc InfoLINUX edisi kali 
ini. 


= 


I ” | E S | 
Prosedur "Linux Ready” % - e? 


Sebuah PC atau notebook © 
yang mendapatkan predikat 
“Linux Ready”, berarti semua 
peripheral standar seperti adapter 
jaringan LAN maupun WLAN dapat 
berfungsi sebagaimana mestinya, 
mulai dari proses instalasi sebuah 
distro Linux dilakukan hingga 
instalasi driver hardware terse- 
but. Distro Linux yang digunakan 
dalam pengujian “Linux Ready” 
adalah, Ubuntu 10.04 LTS, Fedora 
13, dan openSUSE 11.2. 
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DESKTOP/SERVER 


Fedora 13 


PEMBUAT Fedora Project SITUS http://fedoraproject.org 

KERNEL 2.6.33 OFFICE OpenOffice.org 3.2.0, Planner 0.14.4 
DESKTOP GNOME 2.30.0 GRAPHICS GIMP 2.6.8, Shotwell 0.5.2 
MULTIMEDIA Totem 2.30.0, Rhythmbox 0.12.8, Sound Juicer 2.28.2 
INTERNET Firefox 3.6.3, Evolution 2.30.1, Empathy 2.30.1 


edora, distro turunan 
RHEL yang pada saat 
tulisan ini dibuat bera: 
da pada peringkat kedua 
pada daftar situs Distro- 
Watch.com, pada 25 Mei 
2010 lalu telah merilis 
versi terbaru dari distro 
mereka, yakni Fedora 13. 
Versi terbaru dari Fe- 
dora 13 telah membawa 
sejumlah fitur terbaru, 
yang di antaranya, insta- 
lasi driver printer secara 
otomatis, perbaikan dan 
peningkatan aplikasi 
desktop, dukungan 3D 
untuk video card ATi 
(R600 dan R700) via 
driver Radeon, dan 
penyertaan groupware 
Zarafa versi open source. 
Fedora 13 menyer- 
takan GNOME 2.30.0 se- 
bagai default desktop. 
Sejumlah aplikasi yang 
disertakan juga  me- 
rupakan versi  terkini. 
Untuk aplikasi perkan- 
toran, distro ini sudah 
menyertakan Open- 
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Kebutuhan Hardware 


Processor : Kelas Pentium IV 
Harddisk : 20 GB 
Memory : 512 MB 


Office.org 3.2.0. Tak 
ketinggalan juga GIMP 
2.6.8 dan Shotwell 0.5.2 
untuk aplikasi grafis. 
Pada halaman partisi 
di instalasi Fedora 13, 
terdapat penambahan 
opsi, yakni Shrink Cur- 
rent System. Dengan ini, 
pengguna dapat mengu- 
bah ukuran partisi yang 
telah ada untuk mem- 
buat kapasitas harddisk 
kosong yang baru. Selain 
itu, tidak ada perubahan 
terlalu berarti, antara 
Fedora 13 dibanding 
versi sebelumnya.mSup 


Fungsionalitas (20%) EBBEBEER! 9.0 
Fitur (4096) EHE 95 
Kemudahan (30%)  NENNEENNENN| 9,0 
Dokumentasi (10%) MEMMEMEMEN 9,0 
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DISTRO 


PEMBUAT Qimo 4 Kids SITUS www.gimo4kids.com 

KERNEL 2.6.32 OFFICE Orage 4.6.1 EDITOR Mousepad 0.2.16 
DESKTOP XFCE 4.6.1 GRAPHICS ristretto 0.0.22, Simple Scan 1.0.2 
MULTIMEDIA Exaile 0.3.1, Totem 2.30.0 INTERNET Firefox 3.6.3 
EDUKASI GCompris 9.0, Childsplay 1.3, glChess 2.30.0, laby 0.5.5 


engenalan ilmu kom- 

puter dapat dimulai 

sejak dini. Untuk 
melakukan hal ini, di- 
perlukan suatu aplikasi 
yang dapat menjadikan si 
kecil menjadi lebih krea- 
tif. Salah satu distro yang 
dapat digunakan untuk 
hal ini adalah Qimo 4 Kids. 

Dalam distro ini, 
sudah berisi banyak 
aplikasi edukasi untuk 
anak-anak. Qimo 4 Kids 
dibuat berbasiskan Xu- 
buntu 10.04 dan menggu- 
nakan desktop XFCE 
4.6.1. Untuk memper- 
mudah si kecil men- 
jalankan aplikasi dalam 
distro ini, pada bagian 
bawah bar distro Qimo 4 
Kids, sudah diletakkan 
sejumlah icon aplikasi 
edukasi. 

Karena ditujukan un- 
tuk anak-anak di 
bawah 12 tahun, 
tampilan desktop ini 
dibuat agar terlihat se- 
ceria mungkin. Pada 


Kebutuhan Hardware 
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Harddisk : 10 GB 
Memory : 512 MB 


wallpaper yang diguna- 
kan, distro ini meng- 
gunakan wallpaper 
dengan latar belakang 
anak Eskimo, bersama 
seekor beruang kutub 
yang menggunakan pita 
berwarna merah, agar 
dapat menarik perha- 
tian anak-anak. 

Secara default, distro 
ini cukup  menyenang 
kan anak-anak. Hanya 
saja sejumlah paket ap- 
likasi, seperti multimedia 
dan perkantoran, belum 
disertakan secara default 
dalam distro.mSup 


Fungsionalitas (2096) BINAAN 6,0 
Fitur (4096) HHEHNHNHHHEH[])] oO 
Kemudahan (30%) NENNENENN[! 9.0 
Dokumentasi (10%) KENALI 7,0 


RATING 
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GAME 


THIRD-PERSON ACTION 


Lugaru HD 0.0.0.0 Rev269 


PEMBUAT Wolfire Games 
SITUS http://www.wolfire.com/lugaru 


LISENSI GPL HARGA Free (Demo)/Komersial US$19.95 
TINGKAT KESULITAN Medium MULTIPLAYER GAME No 
DEPEDENSI libpng12-0 >= 1.2.13, libopenal1, libsdl >= 1.2.10 


epublik kelinci sedang 

mengalami  kekisru- 

han. Terjadi perbuda- 
kan dan pembantaian 
rakyat Republik Kelinci 
yang dilakukan oleh para 
pemimpin koruptor. Tur- 
ner, sang kelinci pembe- 
rontak berusaha meme 
rangi keadaan ini. 

Plot cerita di atas ter- 
dapat pada game Lugaru. 
Lugaru adalah third-per- 
son action game yang di- 
buat sebagai penerus 
dari game Overgrowth. 
Dalam game ini, Anda 
berperan sebagai Turner, 
kelinci dari kaum pembe- 
rontak yang berjuang 
membebaskan kaumnya 
dari penindasan. 

Pada halaman per- 
mainan, Anda akan di- 
suguhi dengan tiga 
menu utama, yakni En- 
ter, Option, dan @uit. 
Masuk ke menu Enter, 
Anda akan dihadapi 
pada pilihan Tutorial, 
Challenge, dan Change 
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Kebutuhan Hardware 
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Harddisk : 50 MB 
Memory : 512GB 


User. Masuklah ke menu 
Tutorial untuk mempe- 
lajari game ini. Setelah 
dirasa cukup, Anda da- 
pat menuju ke menu 
Challenge untuk memu- 
lai permainan. 

Untuk keyboard 
shortcut, gunakan but- 
ton  W-S-A-D untuk 
arah, Shift untuk 
merunduk, Space untuk 
melompat, dan  klik 
mouse untuk  menye- 
rang. Selanjutnya, An- 
da dapat bertempur 
untuk menghabisi para 
koruptor!mSup 


Hasil Pengujian 


Grafik(30%) HARA ANA 90 





Fitur (40%) ARAHAN nan 7.2 


Kompatibiltas (20%) EBENEN] 7,5 





Dokumentasi (10%) MEMMEMEMEL 9,0 
RATING 


REAL-TIME STRATEGY 


Widelands 1.15-1 


PEMBUAT Widelands Developer 
SITUS http://wl.widelands.org 
LISENSI GPL HARGA Gratis 


TINGKAT KESULITAN Medium MULTIPLAYER GAME Yes 
DEPEDENSI libsdl-gfx >= 1.2, libsdl-mixer >= 1.2, libsdl-ttf >= 2.0 


eragam pilihan game 

strategi sudah tersedia 

di Linux. Sebut saja 0 
A.D., Warzone 2100, Glo- 
bulation 2, hingga Free- 
Col. Jika pilihan game 
strategi ini masih kurang, 
Widelands dapat menjadi 
game alternatif pilihan. 

Widelands adalah ga- 
me strategi di Linux, 
dengan jalan cerita 
yang mirip dengan 
game Settlers II buatan 
BlueByte. Pada game 
ini, Anda akan memulai 
permainan dengan sebi- 
dang tanah yang men- 
jadi lahan dan mem- 
bangun pasukan. Untuk 
mewujudkan hal ini, 
Anda harus mem- 
bangun infrastruktur, 
mengelola lahan, dan 
melawan musuh. 

Seperti game strategi 
yang lain, Widelands 
dapat dimainkan secara 
single player ataupun 
multi-player. Pilihan 
peta permainan yang 
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Memory : 512 MB 


tersedia juga cukup be- 
ragam. Jika ingin mem- 
pelajari dahulu, Anda 
dapat memilih mode 
Campaign dan mengikuti 
tutorial yang diberikan. 
Dalam menu View 
Readme, sudah tersedia 
informasi mengenai key- 
board shortcut permain- 
an. Apabila peta yang 
tersedia dirasa masih 
kurang, game ini juga 
menyediakan menu 
Editor yang dapat  di- 
gunakan untuk mem- 
buat peta permainan 
sendiri.mSup 


Grafik(3096) FPULLLLT LL BS 
Fitur (4096) EHE 20 
Kompatibiltas (20%) SENA 7,5 
Dokumentasi (10%) EEBNENBNENEN| 9,0 
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ANIMATION PROJECT 


Blender Studio 
Projects: Digital 
Movie-Making 


ETUDO PROJECTS 


PENGARANG Sybex 

PENGARANG Tony Mullen, Claudio Andaur 
TERBIT Mei 2010 

HARGA $49.99 (272 halaman) 

ISBN 978-0470543132 

BONUS DVD 


ada dunia multimedia, Linux 

tidaklah lagi dianggap sebagai 

anak bawang. Kenapa? Karena 
banyak film animasi yang sudah di- 
buat oleh aplikasi dari dunia Linux. 
Salah satu contoh film yang dibuat 
adalah Avatar yang menjadi box 
office di Hollywood. Blender adalah 
aplikasi yang dimaksud. Pada buku 
kali ini, Anda akan diajarkan untuk 
menjadi profesional di dalam meng- 
gunakan Blender. Membantu se- 
bagai panduan belajar membuat 
animasi 3D, seperti memperdalam 
atribut dan tool yang digunakan di- 
dalam Blender, membuat konsep 
dan menuliskan cerita, dan 
sekaligus membuat sketsanya. 

Selain itu, terdapat juga pan- 
duan untuk membuat pustaka 2D 
dan 3D secara lengkap, mem- 
bentuk sebuah tekstur, model- 
ling, dan gerakan animasi. Po- 
koknya, semuanya menarik un- 
tuk dipelajari. Bonusnya, Anda 
akan mendapatkan sebuah DVD 
yang berisi file-file panduan, mu- 
lai dari level pemula hingga level 
mahir.mZak 
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DISTRO 


Official Ubuntu Server 
Book, The (2nd Edition) 


«e ubuntu 


Server Book 


PENGARANG Kyle Rankin, Benjamin Mako Hill 
PENGARANG Prentice Hall 

TERBIT Agustus 2010 

HARGA $39.99 (592 halaman) 

ISBN 978-0137081332 

BONUS - 


atu lagi buku tentang distribusi 

Linux terpopuler di dunia saat 

ini, Ubuntu. Namun, kali ini 
yang dibahas adalah versi server- 
nya. Buku ini dibuat untuk Anda 
yang benar-benar baru dalam 
menggunakan Ubuntu server. 
Banyak hal yang dibahas dalam 
buku ini, mulai dari instalasi, 
penggunaan administrasi dan mo- 
nitoring dasar, pengaturan keama- 
nan, dan cara mengatasi masalah 
sistem, menyelamatkan server 
yang rusak parah, dan masih ban- 
yak lagi. 

Buku ini sangat baik sebagai 
tambahan. Anda akan diajari 
cara mudah menggunakan 
Ubuntu server, membantu Anda 
untuk membuat pilihan alat 
keamanan yang cocok untuk 
sistem Anda, membangun server 
yang murah untuk web server 
dan e-mail, meminimalisasi 
kesalahan Anda pada server, atau 
membuat komputer cluster Anda 
sendiri dengan cara yang mudah. 
Jadikan buku ini sebagai referen- 
si Anda.mZak 


BUKU 


SYSTEM ADMINISTRATION 


The Definitive Guide to 
Samba 4 (v. 4) 
[Paperback] 


PENGARANG Roderick Smith 
PENGARANG Apress 

TERBIT Desember 2010 
HARGA $46.99 (650 halaman) 
ISBN 978-1590597835 
BONUS - 


ika di Microsoft Windows ada 

ActiveDirectory, maka di Linux 

ada yang namanya Samba. 
Keduanya mempunyai fungsi dan 
kegunaan yang sama, yang mem- 
bedakannya hanya lisensi, serta 
harga tentunya. Punya keinginan 
untuk beralih menggunakan Samba 
yang sudah teruji kemampuannya 
sebagai pengatur file sharing, 
cobalah baca buku ini. 

Berisi panduan langkah- 
langkah, bagaimana membuat file 
sharing yang baik, mulai dari kon- 
figurasi seperti sharing file, print 
sharing, namun tidak melupakan 
bagaimana cara instalasinya di 
dalam sistem Anda. Selain itu, 
Anda juga akan mendapatkan 
materi tutorial menggunakan 
Javascript yang akan digunakan 
sebagai antarmuka grafis Samba. 

Dari segi keamanan, Anda 
juga akan mendapatkan pan- 
duan dasar untuk membangun 
keamanan file adalah mana- 
jemen pengguna, otomatisasi ad- 
ministrasi, hingga bagian yang 
paling detail dari Samba.mZak 
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SOFTWARE 


DVD/CD sertaan terdiri dari berbagai macam aplikasi 


gratis, shareware, maupun demo. Susunan kategori se- 


lalu berubah, tergantung pada tren aplikasi yang tengah 


berlaku. Beberapa kategori selalu ada di tiap edisi. 


[INTERNET] 
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endengar namanya Saja, pasti 
M Anda sudah mengerti apa fungsi 
dari aplikasi ini. Google Earth 
adalah aplikasi yang digunakan un- 
tuk meneliti tempat di seluruh dunia 
dalam bentuk 3D. Sebuah aplikasi 
yang mendunia dan memiliki fitur 
yang sangat luar biasa. Anda dapat 
melihat bentuk daerah, mencari 
sekolah, dan masih banyak lagi. Ke- 
tik nama daerah pada kolom search 
dan Anda akan langsung menuju 
tempat tersebut. Lakukan zoom un- 
tuk melihat lebih dekat bentuk dae- 
rah tersebut. Anda bahkan dapat 
mencari rumah teman Anda dengan 
aplikasi ini. Tapi, jangan senang 
dulu. Tidak semua daerah bisa lihat 
dan jarak pandangan pun dibatasi. 
Jadi, Anda hanya dapat melihat su- 
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Ln — a Q Cm F — 
sunan rumah ataupun tanah lapang. 
Lebih baik daripada Anda melihat 
peta dan tersesat karenanya. Jika 
memiliki account Google, Anda bisa 
memetakan tempat tinggal Anda 
pada Google Maps. Cari nama dae- 
rah rumah atau kantor Anda, ke- 
mudian berikan pin pada tempat 
tersebut. Berikan juga nama rumah 
Anda sesuka hati. Jadi, kalau ada te- 
man yang sedang menjelajah daerah 
rumah Anda, bisa mengetahui bah- 
wa rumah Anda di daerah tersebut. 
Masih banyak hal yang dapat Anda 
eksplorasi. m Za 


PEMBUAT: Google, Inc. 
SITUS: code.google.com 
LISENSI: Freeware 
DEPENDENSI: - 
REQUIREMENT: - 


INDEX ON 
THE DISC 


DVD 
DISC BOOT 
OO Fedora 13 


[Backup 
O Lucky Backup 
0.4.1 


/Keamanan 

© Universal 
Password 
Manager 1.6 





/Komunikasi 
O Skype 2.1 Beta2 





/Browser 
O Firefox 3.6.6 





O Opera 10.11 





/Monitoring 
© Hardware Monitor 
14.3 





/Codecs 
© Audio 





/Multimedia 
© VLC 1.1.0 





© Video 





© VMPK 0.3.2 





/Desktop 
© Folderview 





/Office 
O Adobe Reader 9.3 





/Development 
© JDK 6u20 





© JRE 6u20 





/DISTRO 
O NexentaStor 
Community 3.0.3 





© OpenOffice.org 
0:22] 





/Pendidikan 
© Perroquet 1.1.0 





/Perkantoran 
O Home Bank 4.3 





O Qimo 4 Kids 2.0 





O wattOS R2 





/Download 
© Vuze 4.4 





/Permainan 

© Ditchers 1.1.1 

© FretsOnFireX 
2027] 








/Email 
O Thunderbird 3.1 





© ¿desktop 1.04 





/EXTRAS 
O Fedora 13 





/Grafis 
O GIMP 2.6.9 





O Mission X 1.0 





[Plugins 
O Flash Player 
10.1.53.64 





/RUBRIK 
O Game 
© Tutorial 
O Utama 











/Internet 
O Google Chrome 
6.0.437.1 Alpha 





O Workshop 





/Virtualisasi 
O VirtualBox 3.2.4 





O Google Earth 5.2 





O (Google Picasa 3.0 
Beta 





DISC RUSAK? 





© : On The DVD Regular 
O : Disc Boot 


Apabila disc yang diterima tidak terbaca atau ru- 
sak dan ingin menggantinya, kirimkan disc yang 
rusak tersebut kepada kami, Tim Disc InfoLINUX, 
Jl. Kramat IV No. 11, Jakarta 10430. Agar dapat 
kami kirimkan disc penggantinya. 
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Sekarang, zamannya Anda meng- 
atur keuangan dengan mudah di 
dalam komputer. Gunakan Home 
Bank untuk mengatur keluar ma- 
suk keuangan Anda, secara pribadi 
maupun untuk usaha Anda. Kon- 
sep dari aplikasi ini adalah ringan, 
sederhana, dan mudah digunakan. 
Jadi, walaupun Anda baru saja 
menggunakan aplikasi ini selama 
5 menit, akan cepat mengerti seper- 
ti Anda sudah menggunakan ap- 
likasi ini sejak lama. Fitur yang 
dapat Anda miliki, antara lain 


FretsOnFireX 3.121 


Ini dia permainan yang banyak di- 
gemari oleh pengguna game yang 
menyukai permainan gitar virtual, 
seperti Guitar Hero dan Rock Band. 
Mengikuti tangga-tangga nada yang 
akan dimunculkan dalam bentuk 
simbol pada tiap line senar gitar 
dan Anda diwajibkan menekan 
tombol permainan mengikuti simbol 
itu. Demikian juga dengan aplikasi 
ini, yang sebenarnya permainan gi- 
tar virtual yang sama dengan per- 
mainan yang disebutkan di atas. Di- 
tulis dengan bahasa pemrograman 
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menganalisis keuangan Anda se- 
cara detail dengan cara yang cepat 
dan dinamis, juga disertai dengan 
laporan yang berdasarkan filter. Se- 
lain itu, Anda juga dapat membuat 
grafik keuangan dengan aplikasi ini. 
Jika menginginkan keuangan Anda 
lebih teratur, cobalah gunakan 
Home Bank. m Za 


PEMBUAT: Maxime Doyen 
SITUS: homebank.free.fr 
LISENSI: GPL / Free 
DEPENDENSI: gtk+ 
REQUIREMENT: - 


Python, Anda dapat memainkan 
gitar, bass, atau drum mengikuti 
lagu kesukaan Anda. Navigasi per- 
mainan ini bisa menggunakan key- 
board, mouse atau instrumen kon- 
trol tambahan yang digunakan pada 
permainan Guitar Hero dan Rock 
Band. Ingin menjadi gitaris andal? 
Mainkan FretsOnFireX. m Za 


PEMBUAT: Chris Painao 

SITUS: code.google.com/p/fofix/ 
LISENSI: GPL / Free 

DEPENDENSI: Python, pygame, NumPy 
REQUIREMENT; - 


SOFTWARE PILIHAN 


[DESKTOP] 


Folderview Screenlet 


Sebenarnya, aplikasi ini adalah se- 
buah widget dari screenlet untuk 
memperindah desktop Anda. Wid- 
get ini akan memudahkan Anda 
untuk meletakkan folder atau 
direktori penting Anda di desk- 
top dengan tampilan yang indah. 
Instal aplikasi ini dan rasakan 
bedanya. m Za 


PEMBUAT: Helder Fraga 
SITUS: gnome-look.org 
LISENSI: GPL / Free 
DEPENDENSI: Screenlets 
REQUIREMENT: - 


[MULTIMEDIA] 


VLC 1.1.0 
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Aplikasi alternatif bagi Anda yang 
ingin menyaksikan ataupun men- 
dengar file multimedia dengan 
banyak format. Di versi terbaru 
ini, Anda dapat menyetel video 
HD dan juga kemampuan stream- 
ing yang baik. Kecepatan melaku- 
kan decoding juga menjadi lebih 
baik. Coba gunakan VLC. m Za 


PEMBUAT: The VideoLAN Team 
SITUS: videolan.org 

LISENSI: GPL / Free 
DEPENDENSI: - 
REQUIREMENT: - 
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SOFTWARE PILIHAN 


[PENDIDIKAN] 


Perroquet 1.1.0 


Amai dde yuu ac 





Bagi Anda yang merasa kesulitan 
dalam melatih pendengaran dalam 
bahasa asing, aplikasi ini cocok 
untuk Anda. Prinsip dari aplikasi 
ini menggunakan audio dan video, 
dan akan diasosiasikan dengan 
subtitle yang berisi perkataan 
yang dihasilkan dari audio yang 
dikeluarkan. m Za 


PEMBUAT: Frédéric Bertolus 
SITUS: perroquet.b219.org 
LISENSI: GPL v3 / Free 
DEPENDENSI: - 
REQUIREMENT: - 


[PERMAINAN] 


Mission X 1.0 








Mission X adalah permainan com- 
bat pesawat yang bertujuan untuk 
menghabisi musuh yang meng- 
hadang. Permainan ini memiliki 
tampilan 2D yang sangat menarik. 
Anda akan mengendalikan kapal 
perang Kapten Mark, dengan misi 
mempertahankan Bumi dari invasi 
bangsa Macronian. m Za 


PEMBUAT: FroggySoft 

SITUS: sourceforge.net/projects/missionx 
LISENSI: GPL v3 / Free 

DEPENDENSI: - 

REQUIREMENT: - 
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GIMP 2.6.9 





Sebuah aplikasi yang berfungsi 
untuk mengolah data image atau 
gambar. Sebuah aplikasi alternatif 
image editing yang memiliki ke- 
mampuan yang sama dengan pe- 
saingnya Photoshop. Walaupun per- 
tama menggunakannya Anda masih 
merasa bingung, tapi lambat laun 
pasti Anda bisa menguasai GIMP. 
Hal yang baru dari versi terbarunya 
ini adalah beberapa perbaikan bugs 
yang ada pada versi sebelumnya, 
2.6.8, dan juga beberapa tambah- 
an penerjemah bahasa. Dukungan 








yang lainnya seperti plugin, script, 
sikat, dan masih banyak lainnya, 
dapat Anda download dari situs 
resminya gimp.org. Bagi Anda yang 
gemar memanipulasi gambar wajib 
menggunakan aplikasi ini, selain 
mudah, tampilan UI yang menarik, 
serta lisensinya yang bersifat open 
source.mZa 


PEMBUAT: The Gimp Team 
SITUS: gimp.org 

LISENSI: GPL / Free 
DEPENDENSI: - 
REQUIREMENT: - 


Virtual MIDI Piano Keyboard 0.3.2 
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Anda ingin belajar bermain key- 
board dalam hal ini alat musik, 
namun belum mampu untuk mem- 
beli piano keyboard asli? Jangan 
mengurungkan niat untuk melan- 
jutkan hobi Anda tersebut. Guna- 
kan aplikasi virtual ini, Anda akan 
dapat bermain piano keyboard 
seperti aslinya. Walaupun hanya 
menghasilkan suara dalam bentuk 
MIDI, namun aplikasi ini menggu- 
nakan tampilan yang mirip sekali 
dengan aslinya. Virtual MIDI ini 
sangat mudah digunakan, walaupun 
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Anda seorang newbie sekalipun. 
Anda dapat menggunakan keyboad 
dan mouse komputer untuk meng- 
operasikannya. Semakin sering 
Anda berlatih, semakin mahir pula 
Anda bermain piano keyboard. 
Dengan adanya aplikasi ini, belajar 
piano keyboard tidak harus mahal, 
bukan? mZa 


PEMBUAT: Pedro Lopez-Cabanillas 
SITUS: kmetronome.sourceforge.net 
LISENSI: GPL v3 / Free 
DEPENDENSI: Ot 

REQUIREMENT: - 
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Dokumentasi Online Berbasis 





Web Wiki 


Masih menggunakan buku sebagai media dokumentasi atau ingin berbagi informasi 


dengan teman Anda melalui Internet? Dokumentasikan dengan mediawiki. 


Informasi merupakan hal yang sangat 
penting di zaman teknologi saat ini. 
Semua hal bisa didokumentasikan, 
dari hal yang sifatnya pribadi mau- 
pun hal yang menyangkut pekerjaan. 
Banyak media yang dapat digunakan 
untuk membuat dokumentasi terse- 
but, mulai dari buku hingga ke media 
Internet. 

Apabila Anda masih menuliskan 
dokumentasi ke dalam buku, bisa saja 
bukutersebutrusak atau lupa meletak- 
kannya, dan akhirnya hilang! Cobalah 
berpikir lebih maju dengan meng- 
gunakan media Internet, salah satu- 
nya adalah menggunakan mediawiki. 
Sebuah aplikasi yang digunakan un- 
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tuk dokumentasi online berbasis web 
sama halnya dengan yang digunakan 
wikipedia. Anda dapat melihat semua 
dokumentasi kapanpun dan di mana- 
pun ketika Anda terhubung dengan 
Internet dan dapat berbagi dokumen- 
tasi dengan teman dan orang lain yang 
melihat dokumentasi Anda. 

Selain itu, teman ataupun orang 
lain dapat menambahkan hal-hal 
yang kurang pada dokumentasi dan 
dapat memberikan masukan dalam 
dokumentasi tersebut. Jadi, dalam 
hal ini Anda tidak sendirian dalam 
mengerjakan dokumentasi dan saling 
melengkapi antara Anda, teman, dan 
pengguna Internet lainnya. 


Mudah digunakan dan juga di- 


dukung dengan tampilan yang 
menawan, menjadikan  mediawiki 
layak untuk Anda coba. 


SKENARIO 


Pada artikel kali ini, penulis menggu- 
nakan distribusi Linux Ubuntu Server 
10.04, sebuah komputer dengan spe- 
sifikasi AMD Athlon, RAM dengan 
besar 256 MB, dan kapasitas hard- 
disk 10 GB. Alasan digunakannya 
Ubuntu Server,agar instalasi lebih 
cepat dan tidak memakan sumber 
daya harddisk. Hal ini membuktikan 
bahwa sebuah server tidaklah harus 
memakai hardware yang mahal. 
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Halaman create account mediawiki. 


INSTALASI PAKET 
PENDUKUNG 


Sebelum Anda melakukan insta- 
lasi mediawiki, paket pendukung 
atau yang lebih dikenal dengan de- 
pendensi harus diinstalasi terlebih 
dahulu. Berikut adalah langkah- 
langkahnya: 

@ Pertama, instalasi Linux, Apache, 
MySQL, dan Php yang disingkat 
lamp, dengan perintah: 

$ sudo tasksel install lamp- 
AVIS 
Pada pertengahan proses, Anda 
akan diminta untuk memasukkan 
password yang akan digunakan 
oleh root MySQL atau admin 
MySQL Anda. 

€ Instalasi juga paket php5, yang 
belum termasuk pada instalasi 
sebelumnya: 

o sudo apt-get install php5 php5- 
gd imagemagick 

@ Apabila semua proses instalasi 
berjalan lancar, cobalah untuk 
melakukan restart untuk Apache2 
dengan perintah: 

$ sudo /etc/init.d/apache2 
pescar 

€ Restart juga service untuk MySQL 
server dengan perintah: 

$ sudo /etc/init.d/mysql restart 


MEMBUAT DATABASE 


Buat database sebagai penyimpan 
data dokumentasi Anda, buka termi- 
nal Anda, dan ikutilah langkah pem- 
buatan database di bawah ini: 

@ Masuk ke dalam database dengan 
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Halaman instalasi mediawiki. 


user root: 
$ mysal su root =p 
€ Masukkan password root mysql 
yang sudah ditentukan pada 
tahap instalasi paket pendukung. 
Setelah masuk, ketik: 
>create database wikidb; 
Perintah di atas akan membuat 
database dengan nama wikidb. 
Tekan ENTER, dan kemudian 
ketik lagi baris di bawah ini: 
select, 


>grant index, create, 


insert, update, delete, alter, 
lock tables on wikidb.* to 
'root'@'localhost' identified by 
'123456'; 
Perintah di atas akan memberikan 
izin akses kepada user root dengan 
password 123456, untuk mengelola 
database wikidb. Setelah selesai, 
keluarlah dari MySQL dengan 
perintah quit: 


SC te 


INSTALASI MEDIAWIKI 


semua dependensi sudah terinstal 
dengan baik, sekarang waktunya 
instalasi mediawiki. Berikut adalah 
langkah-langkahnya: 
€ Masuk ke dalam direktori /var/ 
www: 
Š cd /var/www 
@ Download mediawiki 
menggunakan wget: 


dengan 


$ sudo wget -c http://download. 
wikimedia.org/mediawiki/1.15/ 
mediawiki-1.15.4.tar.gz 
€ Lakukan ekstrak pada file media- 
wiki-1.15.4.tar.gz, dengan perin- 
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Medii ú 15 3 Installation 
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tah di bawah ini: 
$ sudo tar -xvf mediawiki- 
1.15.4.taf.g2 

Ubah nama folder hasil ekstrak, 

supaya lebih mudah diingat men- 

jadi mediawiki: 
$ sudo mv mediawiki-1.15.4 
mediawiki 

Masuk kedalam direktori media 

wiki dan ubahlah izin akses folder 

config: 
$ cd mediawiki 
$ sudo chmod a+w config 

Akses  http://ip webserver/medi- 

awiki, klik "set up the wiki" un- 

tuk mulai konfigurasi instalasi 
mediawiki. Kemudian, Anda akan 
melihat kolom-kolom yang harus 

Anda isikan sesuai dengan kon- 

figurasi yang diinginkan. Hal yang 

harus diisi, antara lain: 

e Wiki name: nama yang diguna- 
kan sebagai judul wiki Anda. 

e Contact e-mail: alamat e-mail 
admin wiki Anda. 

e Admin username: username 
yang akan digunakan sebagai 
username admin wiki. 

e Password: letaknya di bawah 
admin username, password log- 
in admin. 

e Password confirm: konfirmasi 
password yang telah Anda ma- 
sukkan di kolom admin pass- 
word. 

e Database name: nama database 
wiki yang sudah dibuat pada 
langkah buat database, dalam 
hal ini wikidb. 
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UTAMA 


e DB username: nama user yang 
berhak mengelola database 
wiki (lihat proses pembuatan 
database di bagian grant), 
dalam hal ini root. 

e DB password: password user 


yang mengelola database 
wikidb, dalam hal ini 123456. 
e DB password confirm: 


konfirmasi password database 
sebelumnya di atas. 

e Superuser account: klik kotak 
checklist untuk membuat super- 
user account. 

e Superuser name: username 
superuser MySQL yang 
digunakan, dalam hal ini root. 

e Superuser password: password 
superuser MySQL. 


Selain kolom-kolom di atas, 
Anda dapat membiarkannya dalam 
posisi default. Setelah selesai dengan 
mengisi kolom tersebut, klik Install 
MediaWiki! 

@ Selanjutnya, pindahkan file Lo- 
calSettings.php ke direktori /var/ 
www/mediawiki/: 

$ mv /var/www/mediawiki/config/ 
LocalSettings.php /var/www/ 
mediawiki/ 

€ Berikan izin akses terhadap file 
LocalSettings.php: 

$ sudo chmod 755 LocalSettings. 
php 

€ Akses alamat http://ip webserver/ 
mediawiki/ dan Anda akan me- 
lihat halaman utama mediawiki 
yang baru saja diinstal. 


MEMBUAT ACCOUNT USER 


Teman Anda ingin berpartisipasi 
dalam dokumentasi? Buatlah account 
baru dengan cara berikut ini. 

@ Klik link Log in/create account 
pada pojok kanan atas halaman 
utama mediawiki. 

@ Anda akan diarahkan ke hala- 
man login, klik link Create an 
account. 

@ Masukan username account baru, 
kemudian password, retype pass- 
word, e-mail, dan terakhir real 
name. Klik Create account. 

@ Jika berhasil, maka Anda akan 
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disambut dengan halaman wel- 
come. 


PENGATURAN ADMIN 


Pengaturan admin dan user sebenar- 

nya sama saja, yang membedakan 

adalah group antara admin dan user 
biasa. 

@ Login dengan username admin 
pada halaman utama mediawiki. 

@ Klik menu link my prefer- 
ences pada bagian atas kanan 
mediawiki. 

@ Di situ akan tersedia banyak 
menu pengaturan. Menu User 
profile Anda dapat memasukkan 
nama asli Anda, e-mail, signature 
sebagai identitas, jender atau jenis 
kelamin, bahasa yang digunakan, 
penggantian password, dan juga 
notifikasi e-mail. 

@ Pada menu tab Skin, Anda dapat 
mengubah tampilan themes dari 
mediawiki. 

@ Menu tab Files berisi pengaturan 
ukuran batasan resolusi dan 
ukuran gambar atau thumbnails 
yang digunakan. 

@ Date and time berfungsi untuk 
melakukan pengaturan waktu, 
mulai dari format dan timezone 
yang digunakan di daerah Anda. 

@ Editing adalah pengaturan kolom 
editing yang Anda gunakan 
untuk mengisi dokumentasi, ada 
pengaturan ukuran kolom, dan 
pilihan fungsionalitas lainnya. 

@ Recent changes, menampilkan 


catatan log perubahan yang Anda 


atau orang lain lakukan pada 
dokumentasi. 

e Watchlist berfungsi untuk 
menampilkan informasi tentang 
dokumentasi yang sedang Anda 
pantau, dengan  menggunakan 
fitur watchlist. 

@ Search merupakan pengaturan 
pada menu searching dokumen- 
tasi yang akan dicari pada bagian 
mana saja, apakah hanya bagian 
main, di bagian kategori, atau 
yang lainnya. 

@ Misc adalah pengaturan peleng- 
kap, seperti pengaturan justify 
pada paragraf, autonumber, dan 
masih banyak lagi. 


Jangan lupa, ketika Anda selesai 
melakukan konfigurasi untuk 
masing-masing tab, klik tombol Save 
agar tersimpan. Untuk mengemba- 
likannya ke pengaturan default, klik 
Restore all default settings. 


MENGEDIT HALAMAN MAIN 
PAGE 


Halaman main page adalah halaman 
muka mediawiki Anda yang akan 
berisi link-link menuju artikel atau 
discussion Anda. 

@ Login sebagai admin dari halaman 
utama. 

@ Klik menu edit pada tab media- 
wiki dan Anda akan melihat hal- 
aman editing main page untuk 
mengedit isi dari main page. 

@ Hapus semua isi default dari hala- 
man editing main page dan isikan 
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konten yang hendak Anda masuk- 
kan pada main page, misalnya 
Selamat datang. Jika sudah, klik 
Save page. 

€ Anda dapat menampilkan link 
halaman page lainnya pada bagian 
main page. Caranya dengan me- 
masukkan link halaman page ke 
dalam isi konten main page. Beri- 
kut adalah contoh formatnya: 

[ [Judul Page]] 
Dengan membuat link ini, Anda 
dapat langsung mengakses page 
lainnya dari link tersebut. 

@ Selain page, kategori juga dapat 
ditampilkan pada halaman muka 
main page. Isikan baris berikut 
pada isi konten main page: 

[[Category:Nama Kategori] ] 
Sama halnya dengan judul page, 
Anda dapat melihat dokumentasi 
dari link kategori ini. 


MEMBUAT PAGE BARU 


Selain main page, Anda dapat mem- 
buat halaman baru, misalnya Jadwal 
Acara. Ikuti cara di bawah ini untuk 
membuatnya: 

€ Login sebagi admin dari halaman 
utama. 

@ Supaya mudah, buatlah link page 
baru Anda, misalnya Jadwal Acara 
pada halaman main page. Klik tab 
edit pada main page. 

@ Pada editing main page, ketik 
baris berikut ini: 


[[jadwal acaral] 
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Halaman utama mediawiki. 
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Halaman preferences mediawiki. 


@ Selanjutnya, klik tombol Save Page. 
Anda akan melihat link jadwal 
acara pada halaman main page. 

@ Klik link jadwal acara. Jika 
ingin langsung di isi, ketik isi 
pada kolom editing jadwal acara, 
kemudian klik Save Page. 

@ Untuk melihat semua page, klik 
menu Special Page pada kolom 
sebelah kiri mediawiki, di bagian 
toolbox. 

@ Pada bagian List of pages, klik All 
pages. Anda akan melihat page 
jadwal acara yang baru saja Anda 
buat. 

@ Cara lain mengakses page baru 


am | D P T l l l h E 


@r & D #- 


AM rag m. maa aam 


ii» € dba abusus reium] Fem meni iai anm 


Fera, ari EFE: stew LIT, Primi 


Anda, dengan melakukan klik 
pada link page baru di halaman 
main page yang sudah Anda buat 
sebelumnya, dalam hal ini jadwal 
acara. 


MEMBUAT HALAMAN 
DISKUSI 


Anda dapat membuat halaman 
diskusi untuk meletakkan artikel 
dokumentasi Anda. Halaman diskusi 
ini dapat Anda tampilkan pada hala- 
man page berupa link: 

@ Login sebagai admin atau user 
dari halaman utama. 

@ Pilihlah judul page yang akan 
diisikan dokumentasi, misalnya 
main page. 

@ Klik tab Discussion, Anda akan 
diarahkan ke halaman Editing 
Talk:Main Page. 

@ Isikan dokumentasi Anda pada 
kolom textarea yang sudah di- 
sediakan. 

@ Setelah selesai klik Save page, dan 
halaman diskusi Anda sudah ter- 
buat. 


MEMBUAT KATEGORI 


Semua dokumentasi yang telah Anda 
buat dapat dikategorikan secara 
lebih khusus lagi. Dengan kategori, 
maka pencarian dokumentasi jadi 
lebih mudah. 
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Menampilkan gambar di main page. 


€ Pertama-tama, Anda ikuti cara 
pembuatan halaman diskusi 
pada langkah membuat halaman 
diskusi sebelumnya, sampai lang- 
kah keempat. 

@ Sebelum dilakukan penyimpanan, 
tambahkan kategori yang akan 
dimasukkan pada bagian paling 
bawah isi dokumentasi. Tambah- 
kan baris: 

[[Category:Perintah Dasar) | 
Perintah Dasar adalah nama yang 
akan digunakan sebagai kategori 
dokumentasi Anda. 

@ Setelah menambahkan baris di 
atas, segera simpan dokumentasi 
Anda. Klik Save page. 

@ Kategori yang sudah terbuat dapat 
dilihat, klik menu Special pages 
dari bagian toolbox. 

@ Pada bagian List of pages, klik 
Categories. Anda akan melihat 
semua kategori yang ada, telah 
disesuaikan dengan abjad. 

@ Klik nama kategori untuk melihat 
dokumentasi yang ada di dalam 
kategori tersebut. 


MENGGANTI SKIN/THEMES 


Bosan dengan skin default, Anda 

dapat mengubahnya dari skin yang 

sudah disertakan. 

@ Login sebagai admin dari halaman 
utama mediawiki. 


28 08/2010 m INFOLINUX 


@ Klik menu My preferences, kemu- 
dian pilih tab Skin. 

@ Pilih skin yang Anda inginkan, 
dengan mengeklik radio button 
skin. Klik Save. 

@ Pada dasarnya, yang berubah 
hanya skin user saja. Untuk mengu- 
bah skin sebagai halaman default, 
edit file LocalSettings.php pada 
folder /var/www/mediawiki: 

$ sudo vim /var/www/mediawiki/ 
LocalSettings.php 

@ Edit nilai dari bagian $wgDe- 
faultSkin, sesuai dengan nama 
skin yang Anda gunakan. Misal- 
nya nama skin Anda gumaxdd, 
edit $wgDefaultSkin - 'mono- 
book'; menjadi $wgDefaultSkin - 


'gumaxdd"; 
@ Jika sudah selesai, simpan file 
LocalSettings.php, dan refresh 


browser Anda. 
MENAMBAHKAN SKIN/ 
THEMES 
Themes yang digunakan tidak ter- 
gantung dari skin yang sudah diser- 
takan saja, Anda dapat menambah- 
kannya. 
@ Langkah awal, coba download 
themes baru Anda di alamat 
http://mediawiki2u.com/. 


@ Setelah di-download, letakkan file 
skin ke dalam direktori skins di / 


var/www/mediawiki/: 
$ sudo cp nama skin.tar.gz /var/ 
www/mediawiki/skins/ 

@ Masuk ke dalam folder /var/www/ 
mediawiki/skins/ dan esktrak file 
nama_skin.tar.gz: 

$ cd /var/www/mediawiki/skins/ 
Š Sudo tar-xXvE Mella Skin tar.gz 

@ Biasanya, akan terbentuk folder 
dengan nama nama skin. Masuk 
ke folder tersebut dan keluarkan 
isinya, yang biasanya terdiri dari 
satu folder dan satu file php: 

$ cd nama skin 
$ mv * /var/www/mediawiki/skins/ 

@ Setelah isi dari folder nama skin 
dipindahkan maka Anda dapat 
melakukan pengaturan skin, se- 
perti pada bagian Mengganti skin/ 
themes. 


IZIN AKSES PAGE DAN 
DISKUSI 


Pada mediawiki, page dan diskusi 

Anda dapat diedit oleh orang lain. 

Dalam hal ini, user yang sudah 

terdaftar ataupun yang belum ter- 

daftar. 

@ Login sebagai admin atau user, 
kemudian pilihlah diskusi atau 
page yang ingin Anda berikan izin 
akses. 

e Klik link [edit] pada bagian kanan 
judul diskusi atau page. 

@ Klik tab Protect untuk menentu- 
kan proteksi yang digunakan. 

€ Pada bagian Edit, jika Anda ingin 
memberikan izin akses edit semua 
untuk semua orang, baik yang 
terdaftar atau tidak, pilih Allow 
all users. Jika ingin memblok 
izin akses edit untuk user baru 
dan tidak terdaftar, pilih Block 
new and unregitered user, atau 
administrator only untuk tidak 
mengizinkan siapapun mengedit 
page, kecuali admin. 

@ Jika ingin menentukan masa ber- 
laku waktu, pilih pada menu drop- 
down Expires, dimana izin akses 
akan kembali normal (Allow all 
users) ketika waktu yang ditentu- 
kan habis. 

@ Klik Save Page, jika sudah selesai 
memberikan izin akses. 
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UPLOAD GAMBAR 


Pada mediawiki, Anda juga dapat 
melakukan upload gambar. Berikut 
adalah langkah-langkahnya: 
€ Anda harus membuat direktori 
images pada folder mediawiki 
dapat di-writeable: 
$ sudo chmod 777 /var/www/ 
mediawiki/images 
@ Edit beberapa string pada file 
LocalSettings.php: 
$ sudo vim /var/www/mediawiki/ 
LocalSettings.php 
Cari bagian string $wgEnableU- 
ploads dan ubah nilainya dari 
false menjadi true, dan simpan file 
tersebut: 
SwgEnableUploads - true; 
@ Tentukan format yang diizinkan 
pada file DefaultSettings.php: 
$ sudo vim /var/www/mediawiki/ 
includes/DefaultSettings.php 
Tambahkan format gambar pada 
bagian $wgFileExtensions, men- 
jadi di bawah ini: 


SwgFileExtensions = array( ‘png’, 


Sep JLI ‘jpeg’, ‘doe =, 
cle a Clie an): 
€ Ubah juga bagian $wgAllow- 


CopyUploads menjadi true: 
SwgAllowCopyUploads - true: 

Setelah selesai, simpan file De- 

faultSettings.php 

@ Kembali ke halaman main page, 
klik edit untuk mengisi link up- 
load gambar. 

@ Tulis baris berikut untuk meng- 
upload gambar pada bagian edit- 
ing main page: 

[[image:wajah.jpg] | 
@ Klik Save Page untuk menyimpan 


editing. 

@ Pada halaman muka main page, 
klik link File:wajah.jpg. 

@ Di halaman upload file, klik 


Choose File dan browse gambar 
yang Anda akan upload. 

@ Isi Destination filename sebagai 
nama gambar nantinya, misalnya 
wajah.jpg. 

@ Summary adalah keterangan gam- 
bar. Isi jika Anda ingin memberi- 
kan keterangan gambar. 

@ Klik Upload file, jika Anda sudah 
yakin dengan gambar yang akan 
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di-upload. Tunggu hingga proses 
selesai. 

@ Apabila gambar yang Anda sudah 
nampak pada halaman selanjut- 
nya, berarti Anda sudah berhasil 
melakukan upload. 

@ Untuk menentukan posisi gambar, 
Anda dapat mengedit kembali ba- 
gian image dengan baris berikut: 

[[image:wajah.jpg|center|thumb|c 


aption] ] 


Baris di atas menjelaskan bahwa 
gambar wajah.jpg akan berada di po- 
sisi tengah halaman main page, ber- 
bentuk thumbnail, dan juga ada infor- 
masi caption dari gambar tersebut. 


MENGUBAH LOGO 


Berbeda dengan versi sebelumnya, 
mengganti gambar logo pada versi 
terbaru sangatlah mudah. 
€ Persiapkan gambar logo, ukuran 
yang sesuai adalah sekitar 135 x 
135 pixel. Letakkan gambar logo 
tersebut pada folder /var/www/ 
mediawiki/skins/common/images. 
@ Edit file Setup.php yang ada di 
dalam folder /var/www/mediawi- 
ki/includes: 
$ sudo vim /var/www/mediawiki/ 
includes/Setup.php. 

Ubah bagian berikut: 
SwgLogo = “SwgStylePath/common/ 
images/wiki.png"; 

menjadi: 
SwgLogo = "$wgStylePath/common/ 
images/logo Anda.png"; 

@ Simpan file Setup.php, refresh 
halaman mediawiki Anda, dan 
logo sudah terganti. Jika belum, 
coba perhatikan lokasi gambar 
dan nama gambar harus sesuai. 


MENAMBAHKAN EKSTENSI 


Ekstensi merupakan sebuah script 

pelengkap pada mediawiki. Dengan 

ekstensi, Anda bisa mendapatkan 

sebuah fungsi yang tidak dapat 

dilakukan mediawiki. 

€ Download ekstensi yang Anda 
inginkan, kemudian letakkan file 
hasil download tersebut ke dalam 
folder /var/www/mediawiki/ex- 
tensions. 


UTAMA 


@ Jika file ekstensi dalam bentuk 
terkompresi, ekstrak file tersebut 
di dalam folder extension. Dalam 
hal ini, ekstensi yang digunakan 
adalah inputbox: 

$ unzip Inputbox zip 

@ Tambahkan baris berikut kedalam 
file LocalSettings.php pada bagian 
terbawah: 

require once (SIP.' /extensions/ 
inputbox/InputBox pnp’ ) ° 
Simpan file LocalSettings.php, 
jika sudah selesai. 

@ Berikan izin akses pada semua file 
yang ada di dalam folder input- 
box: 

$ sudo chmod -R o+x /var/www/ 
mediawiki/extensions/inputbox 

€ Inputbox adalah ekstensi yang 
digunakan untuk membuat form 
HTML. Untuk mencobanya, den- 
gan memasukkan tag HTML pada 
main page. 

@ Klik edit pada halaman main page, 
tunggu hingga halaman editing 
main page muncul. 

@ Misalnya di sini, Anda ingin mem- 
buat form pencarian atau search, 
masukkan baris berikut pada 
kolom editing main page: 

<inputbox> 

type=search 

width=42 

low E) qute ets lee 
Sean oa aal Segel 
lacak =Y) 

< / NINNE NG 

@ Jika sudah selesai, simpanlah 
dengan mengklik tombol Save 
page. 

@ Anda akan melihat sebuah form 
search pada halaman main page. 
Informasi penggunaan inputbox 
dapat Anda lihat di alamat http:// 
www.mediawiki.org/wiki/Exten- 
sion:Inputboz. 


Semua ekstensi akan diletak- 
kan di dalam folder extensions dan 
Anda juga harus memasukkan baris 
reguire once atau include pada file 
LocalSettings.php, semua tergan- 
tung dari masing-masing instalasi 
ekstensi. m 

Zaky Abdurrachman [zaky.abdurrachman@infolinux.co.id] 
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KOMUNITAS 





alias UMet (Ubuntuers Metro) mengada- 

kan pertemuan atau "kopi darat" kedua 
di Vila Dago Pamulang H22/2 Tangerang 
Selatan, Minggu 27 Juni 2010. Kopdar 
pertama diadakan di Depok, 16 Mei 2010. 
Peserta kopdar kedua ini berasal dari Tanah 
Abang, Citeureup, Bogor, dan lokasi lain di 
seputar Jabodetabek. Bahkan ada Ubuntuer 
dari Medan yang sedang berada di Jakarta, 
turut hadir dalam kopdar kedua. 

Menurut Ketua UMet, Satriyana, kopdar 
dimulai dengan laporan evaluasi kegiatan 
selama sebulan terakhir, dan dilanjutkan 
sesi berbagi ilmu dan pengalaman. UMet 
telah menjalin kerja sama dengan berbagai 
pihak, tidak hanya yang bergerak di bidang 
komputer, tapi juga pengusaha filter air dan 
digital printing. 

Pada kopdar kedua, pemateri asal Bo- 
gor, Egi Adhitia, menyajikan beragam ap- 
likasi sains dan pendidikan, seperti Marble 
dan Stellarium. Pemateri asal Citeureup, 


acus Ubuntu Jakarta dan sekitarnya 





nar tentang Linux dan Free/Open Source 

Software selama Mei-Juni 2010 yang lalu, 
yakni "Gala Ngoprek Komunitas IT Open 
Source" di Depok, Minggu, 23 Mei 2010, dan 
"Free/Open Source Software untuk Pendi- 
dikan" di kampus UBL (Universitas Budi 
Luhur) Jakarta, Kamis 17 Juni 2010. 

Acara “Gala Ngoprek" yang baru per- 
tama diselenggarakan di sebuah mall di De- 
pok itu, berlangsung sejak pukul 9.30 hingga 
18.00 WIB. Panitia penyelenggara “Gala 
Ngoprek” merupakan gabungan dari be- 
berapa lembaga pendidikan di Depok, seper- 
ti LP3T-NF, BSI, dan Poltek Tugu, dengan 
koordinator IGOS Center Depok. 

Hadir sebagai narasumber “Gala Ngop- 
rek”, antara lain Rusmanto dari InfoLINUX, 
Alex Budiyanto dari Sun/Oracle Indonesia, 
Nasirudin dari Eazy Smart Solusindo, Gita 
Surya Wijaya dari Terra mewakili Axioo 
dan Rainer, Agus Setiawan dari komunitas 
Open Solaris, Bonnie Kurniawan dari ko- 


| GOS Center Depok mengadakan dua semi- 














IGOS Center Depok Adakan Seminar 


UMet Adakan Kopi Darat 


Ade Mohammad, menyajikan tip-tip mem- 
percantik desktop Ubuntu dengan Compiz, 
Conky, Screenlets, Cairo-Dock, dan gNome- 
shell. Pemateri asal Pamulang yang sekali- 
gus tuan rumah, Satriyana, mendemokan 
penggunaan Virtualbox untuk remastering 
Sabily Manarat Beta dengan remastersys. 
UMet yang diketuai Satriyana, dengan 
penasihat, Suparno Midi, sekretaris, Aryan- 
dhi, bendahara, Aldebaran Chandra, bidang 
oprekan, Egi Adhitia, dan humas, Muhidin 
Saimin dan Rangga Febrian ini memiliki si- 
tus http://ubuntumetro.okesiip.com.BRUS 





Sebagian penggiat UMet foto bersama saat kopdar. 





munitas Zimbra, Miftahudin dari komunitas 
Blender, dan Egi Aditya serta Dedy Efendi 
dari komunitas Linux. 

Sedangkan panitia seminar Free/Open 
Source Software di kampus UBL hanya 
menghadirkan pembicara tunggal, Rusmanto 
dari InfoLINUX, untuk mengenalkan konsep 
pengembangan Linux dan FOSS lainnya ke- 
pada para mahasiswa jurusan TI di kampus 
tersebut. Seminar ini diselingi dengan demo 
berbagai program di Linux dan pemutaran 
salah satu film “Open Source”. RUS 








Suasana seminar di Universitas Budi Luhur Jakarta. 
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Daftar KPLI yang 
Diketahui Saat Ini 


Bali 
BALINUX 

Situs: http://bali.linux.or.id 
Bandung 

KLUB 

Situs: http://bandung.linux.or.id 
Batam 

BLUG 

Situs: http://batam.linux.or.id 
Bogor 

GRUB 

Situs: http://bogor.linux.or.id 
Gorontalo 

GoLA 

Situs: http://gorontalo.linux.or.id 
Jakarta 

KPLI Jakarta 

Situs: http://jakarta.linux.or.id 
Madiun 

KPLI Madiun 

Situs: http://madiun.linux.or.id 
Makassar 

LUGU 

Situs: http://makassar.linux.or.id 






Maling (MAlang LINux user Group) 


Situs: http://malang.linux.or.id 
Manado 

LUG Manado 

Situs: http://manado.linux.or.id 
Medan 

KPLI Medan 

Situs: http://medanlinux.com 
Padang 

KPLI Padang 

Situs: http://padang.linux.or.id 
Palembang 

MINUX 

Situs: http://palembang.linux.or.id 
Pekanbaru 

KPLI Pekanbaru 

Situs: http://pekanbaru.linux.or.id 
Semarang 

ATLAS 

Situs: http://jateng.linux.or.id 
Serang 

KPLI Serang 

Situs: http://serang.linux.or.id 
Sidoarjo 

KPLI Sidoarjo 

Situs: http://sidoarjo.linux.or.id 
Solo 

KPLI Solo 

Situs: http://solo.linux.or.id 
Surabaya 

KLAS 

Situs: http://surabaya.linux.or.id 
Surabaya 

KPLITS 

Situs: http://its-sby.linux.or.id 
Tangerang 

KPLI Tangerang 

Situs: http://tangerang.linux.or.id 
Yogyakarta 

KPLI Yogyakarta 

Situs: http://jogja.linux.or.id 
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File Server Berbasis NexentaStor 


NexentaStor adalah distro enterprise yang ditujukan untuk solusi 
penyimpanan. Distro ini dibuat berbasiskan Nexenta Gore dan 
berbasis filesystem ZFS. Berikut tahap penggunaan NexentaStor. 


Proses Instalasi NexentaStor 
Berikut tahapan instalasi distro NexentaStor: 


1. 


Pada halaman awal, pilih menu Install NexentaStor 
Community Edition untuk memulai proses instalasi. 
Tunggu beberapa saat hingga installer NexentaStor 
Community mendeteksi keseluruhan perangkat keras. 


. Tahap awal dari installer NexentaStor Community 


adalah halaman Software License. Klik I Agree. 


. Berikutnya adalah halaman Selamat Datang. Klik OK 


an yang sama. Setelah itu, klik Select (Gambar 2). 


. Setelah memilih harddisk yang akan dijadikan tempat 


instalasi, berikutnya akan tampil halaman konfirmasi 
yang menyatakan apakah Anda benar-benar ingin 
melakukan proses partisi kembali, pada harddisk yang 
telah dipilih. Jika sudah yakin dan ingin berlanjut ke 
tahap selanjutnya, klik Yes. 


. Proses instalasi akan segera berlangsung (Gambar 3). 


Tunggu beberapa saat hingga proses instalasi selesai. 


untuk melanjutkan ke tahap selanjutnya (Gambar 1). 
. Pada halaman Fresh Installation, pilih harddisk yang 
akan dijadikan sebagai tempat instalasi NexentaStor. 
Jika berniat melakukan proses mirroring, Anda dapat 
memilih dua atau lebih harddisk yang memiliki ukur- 


Proses Registrasi 

Kali pertama setelah proses instalasi selesai, Anda perlu 
melakukan proses registrasi terlebih dahulu. Berikut se- 
jumlah tahapannya: 
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. Pada menu Grub, pilih opsi NexentaStor Appliance 
[Auto-detect 32-bit/64-bit]. Tekan Enter. 

. Berikutnya akan tampil halaman Software License. 
Pilih I Agree, untuk berlanjut ke tahap selanjutnya. 
selanjutnya adalah halaman untuk memasukkan 
Registration Key. Untuk mendapatkan registration 
key, Anda dapat mengunjungi url http://www.nex- 
enta.com/register-eval, dan masukan Machine Signa- 
ture yang dapat dilihat pada bagian Product registra- 
tion (Gambar 4). Setelah mendapatkan registration 
key yang dikirimkan pada e-mail Anda, masukan key 
tersebut pada opsi Registration Key yang terdapat di 
bagian Product registration (Gambar 5). 

. Tahap selanjutnya adalah konfigurasi jaringan. Pada 
tahap ini, Anda dapat memasukan alamat IP, Sub- 
net Mask, Default Gateway, dan DNS. Anda juga 
dapat memilih untuk melakukan konfigurasi jaringan 
dengan menggunakan IP static atau DHCP. Pilih kon- 
disi yang Anda inginkan (Gambar 6). 

. Pada pemilihan protocol Web GUI, Anda dapat me- 
milih apakah ingin menggunakan protocol HTTP atau 
HTTPS (Gambar 7). Selanjutnya, tentukan juga port 
yang ingin digunakan (Gambar 8). 


Konfigurasi Awal 


Setelah tahapan instalasi selesai, berikutnya terdapat dua 
tahapan konfigurasi NexentaStor yang akan kita lakukan 
via web browser. 
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Tahap #1: Konfigurasi Dasar 


I 


Pada web browser, masukkan alamat berikut pada 
kotak url: http://<Alamat-IP-NexentaStor>:<port- 
yang-digunakan>. Pada contoh ini, penulis memasuk- 
kan alamat http://192.168.1.12:2000. 


. Tahap #1 adalah konfigurasi dasar. Di sini, Anda 


dapat memilih/mengisikan Host Name, Domain Name, 
Time Zone, NTP Server, Keyboard Layout, dan Lan- 
guage, sesuai dengan kebutuhan Anda (Gambar 9). 


. Tahap #2 adalah menentukan password admin. Di sini 


Anda dapat menentukan password root dan password 
admin yang ingin digunakan. Nantinya, user root di- 
gunakan untuk administrasi sistem, dan user admin 
lebih banyak digunakan untuk manajemen Nexenta- 
Stor dari halaman Web/CLI. (Gambar 10). 


. Tahap #3 adalah informasi notifikasi. Masukkan in- 


formasi server SMTP yang Anda miliki, untuk kebu- 
tuhan pengiriman e-mail kebutuhan notifikasi sistem 
(Gambar 11). 


. Tahap #4 adalah penyimpanan konfigurasi. Pada hala- 


man ini, Anda dapat melihat rangkuman dari proses 
konfigurasi yang telah dilakukan. 


Tahap #2: Konfigurasi Jaringan dan Media Penyimpanan 


3 


Tahap #1 adalah konfigurasi kartu jaringan. Pada 
halaman ini, Anda dapat menambahkan kartu jari- 
ngan, melakukan konfigurasi IP, menentukan default 
gateway, dan menentukan DNS server yang akan di- 
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gunakan. Setelah selesai melakukan konfigurasi, klik 
Next Step »» (Gambar 12). 


. Tahap #2 hingga Tahap #5, biarkan saja pada pilihan 


default. Nantinya, proses konfigurasi ini akan kita 
lakukan secara manual. Terakhir, Anda dapat masuk 
ke halaman login Nexenta Management View (NMV) 
untuk memulai proses konfigurasi (Gambar 13). 


Nexenta Management View (NMV) 


Nexenta Management View (NMV) merupakan halaman 
manajemen berbasis web untuk mempermudah konfigu- 
rasi NexentaStor. Berikut sejumlah tip penggunaannya. 


Panduan Gambar 


34 


Pembuatan Account 


Dari menu NMV, klik menu Settings | User. 

Pada menu Users, klik New User. 

Pada halaman Create New Appliance User, isikan opsi 
user name, password, nama group, dan informasi user 
yang ingin dibuat. Setelah selesai, klik Create New. 
Pembuatan user berhasil dilakukan. Lakukan hal se- 
rupa untuk membuat user yang lain. (Gambar 14). 


Pembuatan Data Volume 
@ Klik menu Data Management, lalu klik Data Sets. 


Pada halaman Volumes, jika Anda belum pernah 
membuat data volume, maka akan terdapat informasi 
bahwa belum tersedia volume sama sekali. Klik link 


create untuk membuat sebuah data volume yang baru. 
(Gambar 15). 

Pada halaman pembuatan data volume, Anda dapat 
membuat volume dari harddisk yang tersedia pada 
sistem Anda. Beragam opsi yang berkaitan dengan 
pembuatan data volume tersedia di sini. Mulai dari 
opsi mirroring, RAID-Z1 (single parity), RAID-Z2 
(double parity), dan RAID-Z3 (triple parity). Dalam 
contoh ini, penulis memilih satu dari dua harddisk 
yang tersedia, lalu mengklik button Add to pool >>. 
Pada halaman Volume Properties, penulis mengisikan 
mypool pada opsi Volume Properties, dan memilih On 
pada opsi Deduplication. Setelah konfigurasi dirasa 
cukup, klik Create Volume (Gambar 16). 

Kini pada halaman Volume, sudah tersedia sebuah 
data volume yang telah Anda buat. (Gambar 17). 

Jika suatu saat data volume yang ada dirasa sudah ti- 
dak mencukupi untuk penyimpanan data, Anda dapat 
menambah kapasitas data volume yang ada dengan 
mengklik button + yang terdapat pada opsi Grow. 
Pada halaman Grow Volume, pilih harddisk yang 
ingin Anda tambahkan ke dalam data volume yang 
telah tersedia, lalu klik Grow Volume. 

Saat kembali ke halaman utama Volumes, Anda dapat 
melihat kalau kapasitas volume yang baru ditambah, 
kini kapasitasnya bertambah sesuai ukuran harddisk 
yang ditambah (Gambar 18). 
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Pembuatan Folder 


Masih dari menu Data Management | Data Sets, ber- 
alih ke menu Folder, lalu klik Show. Jika ini adalah 
kali pertama Anda masuk ke menu ini, maka kemung- 
kinan besar tidak ada folder yang pernah dibuat. 
Untuk membuat folder baru, klik tombol here untuk 
membuat folder yang baru. 

Pada halaman Create New Folder, isikan nama folder 
yang diinginkan pada isian Folder Name (jangan 
menggunakan spasi), deskripsinya, dan sejumlah opsi 
lainnya. Dalam contoh ini, opsi Deduplication diak- 
tifkan menjadi On (Gambar 19). 

Saat kembali ke menu Folder, kini sudah terdapat 
nama Folder yang telah Anda buat. 


Share Folder via Samba 


Pada halaman utama folder, pilih folder yang ingin 
Anda share. Setelah itu, beri tanda centang pada 
opsi CIFS yang terdapat pada folder tersebut. Saat 
tampil kotak konfirmasi apakah Anda ingin meng-en- 
able CIFS share untuk folder bersangkutan? Klik OK 
(Gambar 20). 

Agar user dapat menulis folder tersebut, kita akan 


mengubah permission folder share tersebut. Klik pada 
link nama folder share bersangkutan. Tak berapa 
lama akan tampil halaman EDIT FOLDER: nama 
folder share. Dalam contoh ini, untuk mempermudah 
penulis memberi permission kepada seluruh user yang 
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INSTAN 


terdapat pada satu group, penulis mengklik Add Per- 
missons for Group (Gambar 21). 

Pada halaman CREATE NEW ACL ENTITY: nama 
folder share, isikan nama group pada opsi UNIX/ 
LDAP Group. Dalam contoh ini karena group yang 
ingin diberikan permission adalah group staff, maka 
penulis isikan staff. Beri juga tanda centang pada opsi 
Permission to delete a file within a directory dan Per- 
mission to delete the file. Setelah itu, klik Add New 
Group (Gambar 22). 

Proses pembuatan share folder selesai dilakukan. 


Uji Akses Share Folder 


Buka aplikasi Nautillus File Manager. Dari halaman 
Nautillus, ketikan smb://<alamat-ip-server>/. Seba- 
gai contoh di sini: smb://192.168.1.12. Saat tampil 
folder yang telah di-share, double klik folder terse- 
but, maka akan tampil kotak konfirmasi. Masukkan 
dengan username, domains, dan password bersangkut- 
an, setelah itu klik Connect. (Gambar 23). 

Kini, Anda dapat saling berbagi file/folder pada share 
folder yang telah dibuat. (Gambar 24). 


Demikian penjelasan singkat mengenai NexentarStor. 


Informasi lebih lengkap mengenai penggunaan distro ini, 
dapat ditemukan dalam file NexentaStor-UserGuide.pdf 
dan NexentaStor-@uickStart.pdf. M 


Supriyanto (supriyanto@infolinux.co.id) 
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mplementasi Otentikasi Squid 
pada Mode Transparent Proxy 


Dallan Z lari Z luliSan 


ada artikel bagian pertama, sudah dibahas tahap konfigurasi gateway, 


konfigurasi squid transparent proxy, dan pengaturan database. Pada bagian 


kedua ini, akan dilanjutkan dengan pembuatan skrip php untuk implementasi 


otentikasi squid pada mode transparent proxy. 


Membuat script-script php 

Langkah selanjutnya adalah membuat 

beberapa script php yang diantaranya 

adalah rewrite.php, index.php, login. 
php dan logout.php. Isi dari file script 
php tersebut sebagai berikut: 

e File rewrite.php adalah file utama 
yang akan memproses url request 
yang diterima dari squid melalui 
standard input. Url request yang 
diterima oleh rewrite.php berupa 
string single line yang memiliki 
format terdiri dari: 

e Reguest-URI 

e Client IP address and fully 
qualified domain name 

e Users name, via either RFC 
1413 ident or proxy authentica- 
tion 

e HTTP request method 


Contoh url request: 
http://www.contoh.com/index.html 
192.168.1.3/user.host.name henry 
GET 

Script rewrite.php harus meng- 
hasilkan outout berupa string single 
line yang menu njukkan sebuah Re- 
guest-URI dan diikuti sebuah baris 
baru seperti berikut ini: 
http://www.contoh.com/index.html 

Untuk itu buatlah script rewrite. 
php dengan isi file sebagai berikut: 

# 7usr/bin/php 
<?php 
Scon-inysgl ‘connect (~localhost” ,” root 


n" ; "kunci" ) : 
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Sdb-mysgl selectdb (“capo”); 
Stemp = array(); 
while ( $input = fgets(STDIN) ) | 
SEeMD. = split (Simp) = 
Sipe = sepia Oy tempu, 
Sip = $ips[0]; 
Suri=Stemp [0] ; 
Ssql— SELECT coune(*)) FROM logon 
WHERE os" Sp 
Sg-inysgl query (Ssgl), 
Sdata= mysql fetch row(sq) ; 
iE (odatalol I0] >= u) 
{ 

SOUEDUE = 

Stemp[0].”\n"; 
} 
else { 

SOUEDUE = S02: 
https 192.168 1 1 /capo/iIndex. 
pap ubi Sura NU p 

j 


echo $output; 


@ File index.php, adalah script login 
form, dengan isi file sebagai beri- 
kut: 

<l > 

«head» 

«title» Login form </title> 
</head> 

<body> 

<table bgcolors'Stfrttftr' 
border-'0' cellspacing=’ 0’ 
cellpadding=' 0' 

wideh=100%" =<br-<td align=" cent 


er'»«center»«img src=’ logo.png' 


width=340" height=" estes 
«br 

«table width=45%><tr><td 
bgeolor-'sdededce" 
align-'center'»«font size-4 
face=arial color=blue><b>Research 
And Development Division<br></ 
dec truc Apt t 
align-'center'- 

«div style-'border:1px dashed 
red:margin-top:lem: background: 


lightyellow’ > 


<font color=blue><b>Captive 
Portal - Login<b></b> 
=) cas 


<table width= align-'center' 
cellpadding=3 cellspacing=3 
border=0> 
“rorm actions Logn php 
method-POST- 
«input type="hidden” 
name-"uri" value-"«?php echo 
S Garp uri" ] 6952 > 
«center 
KE 
«td width=30% >Username</ 
tals 
«td width=3>:</td> 
<td><input type-text 
name-username maxlength-100 
size=10></td> 
ec bes 


GI > 


«td width=30% >Password</ 
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cos 
«td width=3 
align=center>:</td> 
<td><input type=password 
name=password maxlength=100 
size=10></td> 
EIS 
SBS 
«td width-100$ 
align=center colspan=3><input 
type=submit class=button 
value=Login></td> 


EIS 


</form> 

</table> 
</body> 
</html> 


e File login.php, file ini akan mem- 
verifikasi user dan password yang 
disuplai pada form login. Isi file 
login.php seperti berikut ini: 

<? 
5consmysdgieconnect (“localhost , x 
oot” , kunei” ) g 


Sabanysgi seleerdb “cape: 


Susesname Imm 

POST [username] ) ; 

Spassword = trim($ 

POST [password] ) ; 

Suri = BARIS POST [uses] ) ° 
session start (); 

if ($ POST[username] && ° 
POST [password] ) 

{ 

Ssgl-"select 1 from user 
where username-' Susername' and 
password-md5('$password')"; 

Sq=mysql query(Ssql); 

Sdata-mysgl fetch | 
row ($q) ; 

if (Sdata[0] [0] ==1) 


{ 


isi tile skrip login.php 
selangkapnya, dapat ditemukan 
dalam ekstra DVD InfoLINUX 
edisi ini, dalam folder 

“DVDR DES 1107/2010 /RUBREKY 


netadmin” 


+ + + AE FS # + HF HF +E 
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e File logout.php, isi dari file logout. 
php adalah seperti berikut ini: 
<?php 
ScoOn=y cg! cancer ( localhost , e 
oot” “kunci, 


Sob=mysql selecedb( capo”); 


session Scarth) p; 
$ip=$_SERVER[“REMOTE_ADDR"] ; 
$sql-"DELETE FROM logon WHERE 
ip= sip 

mysql query ($sql); 

session clestroy () 5 

echo “Anda telah berhasil 
logout maka akses internet 
berakhir, <br> jika Anda ingin 
mengakses internet silahkan login 
dahulu, klik di «a href-' index. 
html serale/as" p 


BE 


File rewrite.php selanjutnya disa- 
lin kedalam direktori /usr/lib/squid, 
sedangkan file file index.php, login. 
php dan logout.php disalin kedalam 
direktori penyimpanan dokumen 
web (DocumentRoot). 


Mendefinsikan url rewrite program 
Langkah terakhir adalah 
mendefinsikan url rewerite program 
pada sguid dimana nama program 
rewirte nya adalah rewrite.php. 
Untuk itu Anda harus mengedit file 
/etc/squid/squid.conf dan  aturlah 
parameter url rewrite program 


ik ere ag deen A o fira 


= “pote, 5 L 


adde dim Pr 


Ko Beta Der mas *m oo ud Tos med Dem i] Bark lalai pgn. E. 


x np andana cane AW) erent dace | Ls ih 


NETADMIN 


seperti berikut ini: 
url rewrite program /usr/lib/squid/ 
rewrite.php 


url rewrite cMildren 10 


Setelah itu Anda dapat mengak- 
tifkan squid seperti berikut ini: 
# service squid start 
atau: 
= ee muti dy squid. stare 


dan untuk memungkinkan user 
login terlebih dahulu melalui hala- 
man login yang telah dibuat maka 
service http harus diaktifkan juga, 
lakukan perintah berikut: 
# service httpd start 
atau 
= deb uma c Me tele ad 


Membuat jadwal tugas menghapus 
entri tabel logon 
Agar pada hari berikutnya klien harus 
login lagi untuk dapat mengakses 
web maka buatlah jadwal tugas yang 
akan selalu menghapus seluruh entri 
pada tabel logon setiap hari pada jam 
01:05, untuk itu gunakan perintah 
'crontab -e kemudian buat jadwal 
tugas seperti berikut ini: 
5 qos * * mysql -u root -pkunci 
capo -e "delete from logon" 

Sekian pembahasan mengenai 
otentikasi sguid pada mode trans- 
parent proxy. Selamat mencoba! 

Henry Saptono [boypyt@ gmail.com] 
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Gambar 1. Halaman login otentikasi squid. 
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DAFTAR WARNET BERBASIS LINUX DI INDONESIA 


DKI - Jakarta 


Alcatraz, Kelapa Dua, Kebon Jeruk, Jakarta Barat 
Dexternet, Jl. Meruya Utara No. 33, Jakarta Barat 
Home.Net, Meruya, Jakarta Barat 

Awaludin II, TanahAbang, Jakarta Pusat 

Garasi.Net, Jl. Taruna Raya No. 31, Jakarta Pusat 
Muara Info, Jl. Kramat Jaya Baru Blok G.V No. 476 
Johar Baru, Jakarta Pusat 

ComNet, Petukangan, Jakarta Selatan 

Flash.Net, Warung Buncit, Jakarta Selatan 

Kazenet, Lebak Bulus, Jakarta Selatan 

M-Net Open Source Internet, Jl. M. Kavling No.3 RT 
11/13, Kebon Baru, Jakarta Selatan 

NixNuxNet, Jl. Nangka No. 6 RT 2/5, Tanjung Barat, 
Jakarta Selatan 

Q-Net, Jl. Raya Lenteng Agung, Gardu (Seberang UP), 
Jakarta Selatan 

Simpul, Mampang, Jakarta Selatan 

Tido's.Net, Kebagusan, Jakarta Selatan 

Warnet USS, Jl. Raya Pasar Minggu No.42 Durentiga, 
Jakarta Selatan 

AANet, Condet, Jakarta Timur 

Prima.Net, Kel. Makassar, Jakarta Timur 
WarnetKoe, Pondok Kopi, Jakarta Timur 

Fabian.Net, Latumeten II, Jakarta Utara 

AANet, Plumpang, Tanjung Priok, Jakarta Utara 
Kawan Setia, Jl. Ganggeng Raya No.2a (depan Polsek) 
Tanjung Priok, Jakarta Utara 


Jawa Barat dan Banten 

€ Warnet Nidar, JL. Tentara Pelajar No. 19A, Banjar 
e 

e 

e 


GBM Net, Jl. Babakan Loa No. 57 Cimahi, Depan 

Politeknik Gizi Bandung 

HeroesNet, Jl. Borobudur Ruko 3C, Cibaduyut, Bandung 

Amsterdam Internet Cafe, Jl. Raya Kodau (samping 

Alfamaret), Jatirahayu, Pondok Melati, Bekasi 

Deja Vu Internet Cafe, Jl. Raya Hankam No. 92-94 

Pondok Gede, Bekasi 

Mynett, Jl. Nangka Raya No. 3D Perumnas I Kranji, 

Bekasi 

Taz@net, Pondok Surya Mandala Blok P No. 7 Bekasi 

Selatan, Bekasi 

Data Prima Comp, Cileungsi, Bekasi 

Globalnet, Jl. Jababeka Raya Blok B No. 23 Belakang 

Ruko BCA, Cikarang, Bekasi 

Azoebs Linux Corners, Jl. Babakan Tengah No. 23 

Dramaga, Bogor 

Dev-Net, Jl. Raya Kranggan No. 1 Citeureup Cibinong, 

Bogor 

Game House, Jl. Songgi Raya No. 5, Bogor 

JogloNet, Jl. Siliwangi No. 41 (SMKN 1/ ICT Center), 

Cianjur 

F&D INTERNET, Jl. Salak II Pondok Cina (belakang 

BSI Margonda), Depok 

Majao Computer, Pondok Petir, Sawangan, Depok 

R@ung.net, Jl. Mahakam Raya No. 39 Depok Timur, 

Depok 

Waskita.Net, Jl. Sawo No. 24A Pondok Cina (belakang 

Stasiun UI), Depok 

Warnet Ngenet, Jl. G. Sahari VIII / 11A Gg. Senggol, 

FKM UI, Depok 

Warnet Orbital, Jl. Ir. H Juanda No. 53 Karawang 

Barat, Karawang 

€ Revonet, JL. K.H. Abdul Halim (Depan GGM/UNMA), 
Majalengka 

@ FriendsNet, Jl. Raya OTTISTA No. 20, Depan Rumah 
Sakit PTP VIII, Subang 

@ Warnet Naila, Jl. R.A. Kosasih Gg. Ampera 29, Ciaul, 
Sukabumi 

@ Biru.net, Jl. Angkrek No.74, seberang Gapura ke 
Kampus UNSAP, Sumedang 

@ O'net Cafe, Jl. Surya Darma 34 Sewan, Tangerang 

€ Quantum.net, Jl. Sunan Gunung Jati No 50, Ciledug, 
Tangerang 

€ @.net, Jl. Dr. Cipto Mangunkusumo No. 42, Ciledug, 
Tangerang 

@ Starnet, Cimone, Tangerang 

@ KZ Internet Cafe, Jl. Pesanggerahan No. 49 Rt.3/3, 
Cempaka Putih, Ciputat Timur, Tangerang 

€ Artanita , Jl. Cieunteung No 112 A (Sebelah SMK 
Artanita] Tasikmalaya 

€ Citra [Koperasi Pegawai Telkom], Jl. Otista No. 06, 
sebelah Kantor Pos, Tasikmalaya 

@ Kharisma, Jl. Ampera No. 142, Depan SD Gunung 
Lipung, Tasikmalaya 

@ Warnet Salsabila I, Jl. Rajawali 105, Kp. Siluman, 
Cibeureum. Tasikmalaya 
Warnet Salsabila II, Jl. Kol. Abd. Saleh Cicurug Ojo 
- Cikalang,Tawang, Tasikmalaya 


Jawa Tengah dan Yogyakarta 
Adzkanet, Jl. Raya Pucang-bawang KM 4, Banjarnegara 

4 My-Net, Jl. Menteri Supeno 3C ( (Gedung Perbain It.1) 
Sokaraja, Banyumas 

e SPECTRUMNET, Jl. Kulon 598 Sudagaran Kecamatan 
Banyumas 

€ TopNET, Jl. Raya Jatilawang No. 16 Jatilawang, 
Banyumas 

€ Warnet 88, Jl. Jend. Gatot Subroto 155 Kecamatan 
Banyumas 

@ Warnet BC, Kompleks Terminal Karesidenan Banyumas 

@ Warnet Pigeon, Ruko KUD No. 04, Jl. Wates KM 10 
Sedayu, Bantul 


08/2010 ` INFOLINUX 


ICT Net, Jl. A. Yani No. 68 Kauman, Batang 
MegaNet, Jl. Merbabu 17 Boyolali (samping Rutan), 
Boyolali 

Cafe Net, Jl. Setiabudi No. 17, Brebes 

Fuji Warnet, Jl. Raya Timur Jatibarang Kidul, Brebes 
FOSS net, Kantor Puskud Kab. Brebes 

Lestari Net, Jl. Hj. Siti Aminah No. 23 Dukuhturi 
Bumiayu, Brebes 

AJ-Net, Jl. Urip Sumoharjo 9b Limbangan, Cilacap 
Hastama-Net, Jl. Gerilya 88a Sampang, Cilacap 
PojokNET Internet Cate, Jl. Tugu Barat No. 1 
Sampang, Cilacap 

Metrijaya Net Cafe, Jl. A. Yani No. 12 (Depan 
POLSEK) Adipala, Cilacap 

Tracert Cyber Station, Jl. Raya Jepara Kudus, 
Pecangan Kulon RT 03/02, Jepara 

Java Net, Jl. Duwet No. 4, Karangasem, Kartasura 
Gifa Net, Jl. Raya No. 148 Cepiring, Kendal 
Fir@.Net, Jl. Kh. Noor Hadi No. 34 B (Samping 
Asrama Akper Muhammadiyah), Kudus 

Tit@ Net, Jl. Juwana-Pati KM. 1 No. 2 (Hotel Graha 
Dewata Juwana), Pati 

WWCE, Jl. Untung Suropati 33 Tayu, Pati 
AnantaNet, Jl. Diponegoro, masuk gang Utara Pasar 
Induk Kajen, Pekalongan 


@ KiosNet LiPI Linux, Jl. Bugenvil Rt.06/07 Purwoharjo 


Comal, Pemalang 

Aidea.net, Jl. S. Parman No. 4, Purbalingga 
AlfaNET, Jl. Ahmad Yani No. 1b Lt. 2 Alfamart Depan 
Terminal, Purbalingga 

GaneshaNET, Jl. Piere Tendean No. 81 Selatan Alun- 
alun, Purbalingga 

JULIOS, Jl. Pujowiyoto 5 b, Purbalingga 

Banyu-Net, Jl. dr Soerparno No.18, Purwokerto 
Warnet 88, Jl. Jend. Sudirman Timur 172 Berkoh, 
Purwokerto 

Dago7 Net, Jl. Dr. Soeparno No. 12, Purwokerto 
Naurah.Net, Jl. Kutoarjo - Ketawang Km. 6, 
Dukuhdungus, Grabag, Purworejo 

Alfa.Net, Parang Barong Sguare 14 Kav 04, Semarang 
Andromeda.Net, Jl. Tanjungsari No. 4, Semarang 
CafeNet69, Jl. Tlogosari Raya 1/69, Semarang 
Exsanet, Jl. Jati Raya Blok Ck3 Ruko Banyumanik, 
Semarang 

GankbuntU WarunglInternet, Jl. Purwoyoso Ic No.30, 
Semarang 


€ GrandNet - 1, Jl. Sirojudin No. 5 Tembalang, Semarang 
€ GrandNet - 2, Jl. Thamrin No. 12 Sebelah Pertamina, 


eee ec. 000 


Semarang 

HitNet (GrandNet - 3), Wonodri Baru No. 31 Belakang 
RS Roemani, Semarang 

Homenet, Jl. Majapahit 281A, Semarang 

IdolaNet, Jl. Indraprasta, dekat SPBU, Semarang 
Infoesia.Net, Jl. Gusti Putri II/No. 40, Semarang 
Magesen Internet Cafe, Jalan Patriot I H-77, Semarang 
Mataram, Jl. MT Haryono 294-296, Semarang 
Starcomp, Jl. Karanglo Pedurungan, Semarang 
Star@net, Jl. Karanglo I No. 64, Semarang 

TrendNet, Jl Tirto Agung No. 13 Banyumanik, Semarang 
WSI Net, Jl. Prof. Sudharto, Tembalang (samping Cafe 
Tugu), Semarang 

Zulinet, Jl. Plamongan Sari Raya 3A, Semarang 
Warnet Amanah, Jl. Raya Sukowati 640, Sragen 

A Ha 7 Comp, Jl. Raya Balamoa - Banjaran 20 
Pangkah, Tegal 

BIXnet, Jl. Pancakarya No. 19 Kajen Talang, Tegal 
BONeX, Jl. H. Samanhudi No. 33 Trayeman Slawi, Tegal 
Brug Abang 99 Warnet, Brug Abang Kajen Talang, Tegal 
BSC Net, Jl. Raya Karanganyar, Tegal 

Era Net, Jl. Moh. Yamin Slawi, Tegal 

Fudu Net, Jl. Pala Raya No. 45 Mejasem, Tegal 
Graficia Warnet, Jl. Srigunting No. 41, Tegal 
KSnetcafe, Jl. Abimanyu Kedungsukun, Tegal 

La Tanza Net, Jl. Samadikun Debong, Tegal 

Melati Net, Debong, Tegal 

Nasa Net, Jl. Nakula, Tegal 

Oase Net, Jl. Werkudoro, Tegal 

Queen Warnet, Jl. Werkudoro, Tegal 

RedMouse Internet Cafe, Jl. Sumbodro No. 34, Tegal 
Soto 99 Warnet, Jl. Raya Talang, Tegal 

Super Net, Jl. Raya Singkil No. 22 Adiwerna, Tegal 
Tecra Net, Jl. Setia Budi No. 35, Tegal 

Wings Net, Tembok Luwung, Adiwerna, Tegal 

Happy Net, Jl. Gatot Subroto No. 15, Ungaran 
PoiNTER Multimedia, JL. Gatot Subroto 151, Ungaran 
Upnet, Jl. Maospati Raya No. 39, Pondok Babadan 
Baru, Selamarta, Babadan, Ungaran Timur 
NugrahaNet, Selomerto No. 150, Wonosobo 

i-KG.Net, Jl. Ngeksigondo No. 62 Kotagede, Yogyakarta 
Jo.Net, Jl. Bantul KM 8,5, Yogyakarta 


awa Timur dan Bali 


Bee Cyber Warnet & Hotspot, Perum Telang Indah 
Persada, Jl. Telang Indah Barat I No. 29 Telang, 
Kamal, Bangkalan 

Warnet Galaxy, Jl. A. Yani 03 (depan SMA 1), Blitar 
Warnet Mitra, Jl. Lawu No. 71, Blitar 

Setya Jaya Net, Jl. Panglima Sudirman No. 13, 
Bojonegoro 

SAGA-NET, Jl. dr. Wahidin SH No. 620, Gresik 
XNET, Ruko Pesona Jawa B-3, Hi-Tech Square, Jember 
Zencafe i-Net, Jl. Kartini 1A, Banyu Biru, Jombang 
Arnet, Jl. Welirang, Kediri 





At Taqwa, Madrasah Aliyah Negeri 3, Kediri 

Orange Net, Ruko Stadion Brawijaya A3, Kediri 

Titanium.Net, Jl. KH. Wakhid Hasyim, Kediri 

Warnet Bima, Kediri 

Warnet Bina, Kediri 

Warnet ERA, Jl. Raya Kolak 21, utara MTs, depan 

ALKABA Swalayan, Kolak, Ngadiluwih, Kediri 

Warnet Evo, Kediri 

Warnet FastNet, Kediri 

Warnet Plus, Jl. Ahmad Yani, Ruko Stadion Brawijaya 

C-5, Kediri 

Warnet PoS Kediri, Jl. Mayjen Sungkono 32, Kediri 

Warnet Putra Surya Computer, Kediri 

Warnet AWF, Jl. Raya Sugio-Kedungpring, Sugio, 

Lamongan 

@ Warnet Maju Jaya, RT 03 RW 02, Siman, Sekaran, 
Lamongan 

@ Warnet SMK Wachid Hasjim, Parengan, Maduran, 
Lamongan 

€ TuxEdoe, Jl. Panglima Sudirman, Purwosari, 
Wonoasri, Caruban, Madiun 

€ Warnet Ubuntu, Jl. Raya Genengan No. 256 Rt/Rw 
03/09, Binangun, Pakisaji, Malang 

@ Warnet Mandiri, Jl. R. Wijaya 5 (Depan Stadion Gajah 
Mada) Mojosari, Mojokerto 

€ Warnet Paradise, Jl. Raya Kemantren, Kec. Gedeg, 

Mojokerto 

Best.Net, Jl. Musing 633 Kauman, Bangil, Pasuruan 

F@S Warnet, Jl. Durian No. 281, Bangil, Pasuruan 

Bluesky.net, Krajan 05/01, Desa Banjarsawah, 

Tegalsiwalan, Probolinggo 

ARFnet, Jl. Dharmawangsa No. 56B, Surabaya 

Ciber Net, Jl. Simo Kwagean No. 72, Surabaya 

Deepo.Net, Jl. Danakarya No.77 Surabaya 

KampoengCyber, Rungkut Asri Utara No. 9, Surabaya 

RC Net, Jl. Siwalankerto 1/66, Surabaya 

Shinobi.Net, Jl. Mulyorejo 174, Surabaya 

Warnet Smart Office, Karang Menjangan 72, Surabaya 

Warnet Pacarkembang, Gang 3 No. 36, Surabaya 

Prompt.Net, Sidokare Asri Ai/9, Sidoarjo 

Core.Net, JL. Basuki Rahmat 37, Situbondo 

AE Net, Desa Mandirejo, Kec. Merakuran, Tuban 

Bina Tuban, Jl. Basuki Rahmat 73, Tuban 

Hasil Flash Net, Jl. Basuki Rahmat No. 235, Tuban 

Planet Com, Jl. Basuki Rahmat No. 320, Tuban 

Sudra Net, Jl. Basuki Rahmat No. 57, Tuban 

Tamim Net, Jl. Diponegoro No. 45, Tuban 

Toki Net, Jl. KH. Musta'in No. 50, Tuban 

Liberty Cyber, Jl. Gn. Rinjani IXC No. 8, Denpasar, Bali 

YOGA INTERNET 1, Jl. Patimura No 4, Tabanan, Bali 

YOGA INTERNET 2, Jl. Gajah Mada 128, Tabanan, Bali 

YOGA INTERNET 3, Jl. Raya Mengwitani, Badung, Bali 


Kalimantan 

@ Flink Internet Cafe, Jl. Adhyaksa Komplek Ruko Kayu 
Tangi Permai No R11, Banjarmasin, Kalsel 

@ Ciwank.net, Jl. Pramuka No. 15, RT/RW 29/10, Kel. 
Gunung Kelua, Samarinda, Kaltim 


Sulawesi 
MECS, Jl.Mesjid Raya No.17 Sungguminasa, Gowa 
° @mAy- Net, J1. Abd. Silondae No. 127 C (samping 
BCA), Kendari 
€ Aromanet, Jl. D.I. Panjaitan No. 88 Lepo-lepo 
(samping Trakindo), Kendari 
€ Jelajah Net, House of Linux. Jl. Perintis Kemerdekaan 
VIII no. 2B, Makassar 
K-Sepuluh Net, OpenSourceNet Cafe, Jl. Perintis 
Kemerdekaan Km.10 No.36, Makassar 
LouphNet, Jl. Aroepala, Hertasning Baru B2 No.26 
(Samping Kampus STIKES Mega Rezky), Makassar 
Toraja.Net, Ruko O3, Jl. Perintis Kemerdekaan KM 12, 
Makassar 
Zenith Internet Cafe, Jl. Kumala No. 43 A, Makassar 
Kirei Net, Jl. Sam Ratulangi 159 (depan BCA), Manado 
Warnet Sintek (Sinjai Teknologi), Jl. Baso Kalaka No. 
10 Sinjai, Sulawesi Selatan 


Sumatera 


Jack.Net, Jl. Medan-Banda Aceh, Matangglumpang 
Dua, Bireuen, Aceh 

e Tarisa, Ruko Simpang Kantor Pos Keutapang, Aceh 
Besar 

€ Opotumon, Jl. Tgk. Chik Dipineung Raya No. 69, 
Kampung Pineung, Banda Aceh 

€ Mianova.Net, Jl. Hayatimahim No. 2 RT 20 RW 08 
Tanjungpandan Belitung, Bangka Belitung 

€ Homy.net, Citra Batam C.233 Batam Centre, Batam, 
Kepulauan Riau 

@ Kaliber Net, Jl. Pemuda No. 22e Tanjungpinang, 
Kepulauan Riau 

@ Ulisa.Net, Jl. Cempedak No. 84 Dumai, Riau Daratan 

@ Kagaya.Net, Jl. Abdul Muis No. 9A, Jati, Padang, Sumbar 

€ AndiNet, Jl. Palembang Batas Kota, samping RM 
Lesehan Lumayan II, Muara Enim, Sumsel 

@ Delta.net, Jl. Mayor Ruslan III, Pasar Lama, Lahat, 
Sumsel 

@ IndahNyo.net, Jl. Pelda Saibi No. 1/40 Nasional, 
Prabumulih, Sumsel 

@ Kambangiwak.net, Jl. Palembang-Prabumulih KM 32 
depan Bank Sumsel, Inderalaya, Sumsel 

€ Nikita.net, Jl. Jend. Sudirman, Simpang Muara Dua, 
Samping Atlas, Prabumulih, Sumsel 
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TUTORIAL MYSQL VIA HTTP 





Pada InfoLINUX Juli 2010, kita 
membahas tentang python-UNO, di- 
mana dengan menggunakan python 
kita bisa mengakses fungsionalitas 
OpenOffice.org dari luar. Pada edisi 
ini, kita akan membahas contoh lebih 
lanjut, dimana data dari spreadsheet 
akan diambil dan disimpan ke data- 
base server MySQL. 

sayangnya, ada satu masalah: py- 
thon versi 2.3.4 yang datang bersama 
OpenOffice.org 2.3 yang penulis guna- 
kan, tidak disertai dengan modul 
untuk bekerja dengan MySQL. Se- 
mentara, kompilasi/instalasi seper- 
tinya cukup merepotkan. 

Beberapa saat lalu, penulis masih 
memiliki harapan: mencari modul py- 
thon untuk bekerja dengan MySQL, 
tapi yang dibangun sepenuhnya de- 
ngan python (pure python). Tanpa 
melibatkan link ke pustaka client 
MySQL. Beberapa sempat penulis 
temukan (sekilas), namun sayangnya 
tidak dapat digunakan karena mem- 
butuhkan python dengan versi yang 
lebih tinggi dari 2.3, atau modul ber- 
ada dalam status belum layak pakai. 

Karena ada kebutuhan lain yang 
mirip-mirip, penulis memutuskan 
untuk membangun dboverhttp. Se- 
suai namanya, fungsi program ini 
adalah melewatkan guery yang kita 
berikan (lewat HTTP) ke database 
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bangun bersama dalam tulisan ini. 


server, dan mengembalikan hasil 

guery. Dengan demikian, kita hanya 

perlu berbicara dengan HTTP Server 
dan tidak langsung dengan database 
server itu sendiri. Lebih lambat pasti- 
nya. Tapi, bagi yang hanya memiliki 
akses lewat HTTP atau modul untuk 
bekerja dengan database tidak terse- 
dia, ini merupakan salah satu solusi. 

Berikut adalah beberapa fitur 
program: 

@ Bekerja dengan protokol HTTP. 
Dengan demikian, dapat digu- 
nakan hampir dari mana saja. Di 
python, kita bisa menggunakan 
modul urllib. 

@ Menggunakan YAML (yaml.org) 
sebagai format serialisasi out- 
put. Penulis telah beberapa lama 
menggunakan YAML dan sejauh 
ini sangat puas. Plus, tersedia 
modul yang dibangun dengan py- 
thon murni dan dapat berjalan 
pada python 2.3. Pustaka untuk 
bekerja dengan YAML juga terse- 
dia untuk sangat banyak bahasa 
pemrograman. 

@ Dapat bekerja dengan berbagai 
tipe database server. Sebagai 
contoh: MySQL, PostgreSQL dan 
SQLite. Dalam versi awal ini, se- 
mentara kita fokuskan ke MySQL 
terlebih dahulu. 

@ Mendukung caching (nantinya). 


pakah Anda ingin mengakses database server, tapi tidak bisa melakukan 
koneksi secara langsung? Atau modul untuk bekerja dengan database tidak/ 
belum tersedia? Anda bisa gunakan dboverhttp, proyek yang akan kita 


Program dboverhttp akan diba- 
ngun sepenuhnya dengan python, 
berbasis web, dan menggunakan 
pustaka web.py (webpy.org). Apabila 
diperlukan, bacalah pembahasan 
tentang web.py pada InfoLINUX 
05/2009. Web.py, termasuk cara 
melakukan guery ke database, tidak 
akan dibahas lagi dalam tulisan ini. 
Kita juga tidak akan membahas de- 
tail format YAML (informasi seleng- 
kapnya: yaml.org). 

Pembahasan akan dibagi dalam 
beberapa topik berikut: 

@ Koneksi, guery, dan keamanan. 
Format output dan hasil guery. 
URL dan form. 

Contoh database. 

Source code dboverhttp dan pen- 
jelasan. 

@ Contoh client: python. 


Semua contoh program dibangun 
di atas Singkong Linux 1.0 (nopri- 
anto.com), namun harusnya dapat 
diterapkan pada sistem lainnya. 

Program dboverhttp merupakan 
program free/open source dan dili- 
sensikan GPL. 


Koneksi, Query, dan Keamanan 
Untuk versi awal ini, berikut bebe- 
rapa pertimbangan tentang koneksi, 
guery, dan keamanan secara umum. 
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Setiap pengguna harus memberi- 
kan informasi koneksi database, 
seperti hostname, port, tipe da- 
tabase, username, password, dan 
nama database lewat dboverhttp. 
Demikian juga dengan query 
string database. Informasi-infor- 
masi ini tidak akan pernah disim- 
pan. 

Request method yang diperguna- 
kan adalah selalu POST. Kecuali, 
nantinya ada konten informatif 
non-database yang akan dikem- 
balikan. 

Saat ini, query akan diberikan apa 
adanya dan akan langsung dile- 
watkan ke database server tanpa 
modifikasi atau pemeriksaan 
apapun. Pemeriksaan keamanan 
seperti pencegahan akan SQL In- 
jection harus dilakukan dari sisi 
client. 

Apabila diperlukan, kita bisa 
menggunakan HTTPS. Ini berada 
di luar cakupan tulisan. 


Format Output dan Hasil Query 

Untuk versi awal ini, berikut adalah 
beberapa pertimbangan tentang for- 
mat output/response dan hasil guery. 


Seperti disebutkan sebelumnya, 
format output/HTTP response 
adalah YAML. Versi YAML yang 
digunakan adalah 1.1. 

Output yang merupakan YAML, 


setelah di-load, akan selalu meru- 

pakan sequence dengan dua ang- 

gota: 
(etatus, Guery result) 

e status merupakan bilangan bu- 
lat, dimana 0 atau lebih þesar 
menandakan operasi sukses 
dan bilangan negatif menan- 
dakan operasi gagal. Bilangan 
lebih besar dari 0 merupakan 
affected rows (apabila ada). 

@ query result merupakan hasil 
guery itu sendiri (dalam ben- 
tuk seguence) atau seguence 
kosong, apabila tidak terdapat 
hasil guery/hasil guery tidak 
diperlukan. 

@ Di masa depan, apabila diperlu- 
kan, output dapat dikompres. 


URL dan Form 


Untuk versi awal ini, berikut adalah 
beberapa pertimbangan tentang URL 
dan form HTML. 

@ Secara default, reguest method 
adalah POST. 

@ Saat ini, URL yang digunakan 
hanyalah /guery. Setiap kali guery 
diberikan, koneksi database akan 
dibuat. Dengan demikian, ber- 
sama guery string, kita juga harus 
memberikan informasi koneksi. 
Tidak ada session yang di-main- 
tain. 

@ Informasi koneksi dan guery yang 
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kita butuhkan adalah: 

e dbn: tipe database (untuk 
MySQL, kita berikan: mysgl). 
host. 

port. 

user. 

pw. 

db: nama database. 

guery: guery yang siap di- 
jalankan. 


Di masa depan, kita mungkin 
akan me-maintain session, sehingga 
koneksi hanya perlu dilakukan sekali 
saja. Setiap kali guery, yang kita bu- 
tuhkan hanyalah informasi berupa 
guery string. 


Contoh Database 


Sebagai contoh database, kita akan 
mempergunakan MySQL. Nama da- 
tabase adalah: dboverhttp test. 
€ Sebagai root MySQL, buatlah da- 
tabase tersebut: 
mysgl» create database 
dbovechibrparcce, 
Query OK, 1 row affected (0.04 
sec) 
€ Berikan hak kepada user 
dboverhttp@localhost, dengan 
password adalah: password: 
mysql» grant all privileges 
on Gawean test TO 
dboverhttp@localhost identified by 
‘password’ ; 
Query OK, 0 rows affected (0.00 


sec) 


mysql» flush privileges; 
Query OK, 0 rows affected (0.00 
sec) 
€ Sebagai dboverhttp@localhost, 
buatlah tabel berikut: 
mels úse dboyerhtt TeSt; 


Database changed 

mysql» create table test (a 
integer, b varehar (iG) ): 

Query OK, 0 rows affected (0.01 


sec) 


mysql> dese TeSt, 
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| WES | 


2 rows in set (0.00 sec) 


Source Code dboverhttp dan 
Penjelasan 

Sebelum membahas tentang source 
code dboverhttp, kita akan siapkan 
semua pustaka yang diperlukan ter- 
lebih dahulu. Selain pustaka yang 
bisa diinstal secara lokal (dibangun 
dengan python murni), agar web.py 
dapat bekerja dengan MySQL, pasti- 
kan modul MySQLdb (http://source- 
forge.net/projects/mysql-python/) 
telah terinstal. Instalasi MySQLdb 
tidak dibahas di dalam tulisan ini. 


Direktori dan Pustaka Lokal 
@ Buatlah sebuah direktori dengan 
nama  dboverhttp. Anda bisa 
tempatkan di manapun direktori 
tersebut: 
$ mkdir =v dboverhttp 


mkdir: created directory 


~dboverhttp’ 
@ Masuklah ke dalam direktori 
tersebut: 


cd dboverhttp/ 
@ Kita akan membutuhkan web.py. 
Download-lah terlebih dahulu: 
$ wget http://webpy.org/static/ 
web.py-0.34.tar.gz 
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Situs web yaml.org. 
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@ Kemudian, installah web.py: 
S tar zxft web. py-0.34.tar.az 
$ mv web.py-0.34/web 
$ rm -rf web.py-0.34.tar.gz web. 


py-0.34 
@ Kita juga membutuhkan PyYAML 


(untuk bekerja dengan YAML). 
Download-lah dengan perintah be- 
rikut: 
$ wget http://pyyaml .org/ 
download/pyyaml/PyYAML-3.09.tar. 
gz 
@ Dan, installah PyYAML: 
$ tar zxt PyvAME-S.09 tar. gz 
$ mv PyYAML-3.09/lib/yaml 
$ ii ort PyYAML=32 109 tam qz 
PyYAML-3.09 
€ Semua pustaka yang dibutuhkan 
telah kita miliki: 
Sis T 
total 
drwxrcxr-x 4 nop users 4096 2010- 
03-21 00:43 web/ 
dye 2 nop users), 4096 2009- 
08-31 16:16 yaml/ 
€ Persiapan selesai 


Source Code 

Masih di dalam direktori dboverhttp 

sebelumnya, buatlah file dboverhttp. 

py, dengan isi sebagai berikut. 
#!/usr/bin/env python 


= 

# dboverhttp 

# version alaa il 
# license : GPL 


# started by = Noprianto <noprianto. 


com» 
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# credits 


# - put your name here «email» 


«credit» 


" 


import web 


import yaml 


web. 


default error = 


default ok - 


urls 


app 


config.debug - 


= | 
Meja Sana, 
) 


"enses y 


False 


= web.application(urls, 


globals()) 


der dump(o, sabe-Irue, deraule) tow) 


styl 


e=False): 


dumper = yaml.safe dump 


if not safe: 
dumpex = 
try: 


ret - 


yaml.dump 


dump erko Gelahe iow 


style-derdultilow style) 


except: 
rer m 
# 


return ret 


class query: 


def POST (self): 


L = Web. input ( 


dion Skk 
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potu 
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user= s, 
OWS r1 F 
dil 


gue 


# 
Ery: 
loore = inme (ak pore) 


except ValueError: 


loore = © 
# 
By: 
conn = web.database ( 
diga econ, 
host = 7 host, 
pos = most, 
user = 1.user, 
DW = PW 
cio aly, lle}, 
) 
r = conn.guery(i.guery) 
except 
return dump (derang 
error) 
H 
pet = defaule error 
res = [] 
ik bype (se) s= typettkh) ot 
type(r) == type(1): 
ret s |r, 788] 
ES 
TOE @ im re 
temp = () 
for b in a.keys(): 
temp[b] = a[b] 
res.append (temp) 
ret = [0, res] 
# 


return dump(ret) 


app.run() 

Dari halaman terminal, jalankan- 
lah server dengan perintah berikut: 

$ python dboverhttp.py 
http://0.0.0.0:8080/ 

Secara default, server akan di- 
jalankan pada port 8080. Untuk 
menjalankan pada port lain, tambah- 
kan port sebagai argumen program. 
Contoh: 

$ python dboverhttp.py 9000 
http://0.0.0.0:9000/ 

Atau, sertakan IP apabila perlu: 
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S python dboverhttp.py 
12150012 IMO) 
Heep 7 127 30.0 900107 


Penjelasan: 

@ Kita siapkan sebuah fungsi bantu 
untuk dump ke YAML. Secara 
default, kita gunakan safe dump 
sehingga hanya menghasilkan 
tag YAML standar. Serialisasi 
dilakukan dalam block style (de- 
fault flow style-False). Di masa 
depan, apabila diperlukan, ini 
bisa diberikan sebagai opsi dalam 
guery: 

det cimol, sate=True, Cetault 


flow style-False): 


@ Kita dapatkan input dari client 
dengan nilai default: 
Class guery: 
def POST(self): 
i = web. input | 
da 
hose 
porte 5, 
users" " ,; 
pw='', 
db-'', 
query-'', 
) 
@ Lakukan konversi port ke integer: 
ry 
Hort = ime (L port) 
except ValueError: 
pott 
E 
@ Kemudian, coba melakukan ko- 
neksi dan mengirimkan guery. 
Apabila gagal, kembalikan dump 
dari default error ([-1, Ill): 
Cry: 
conn - web.database( 


din = 1 dbm, 


NOSE = il, host 


portis Iport, 
user = i.user, 
Dw = id Ow, 
dlò = dis» 
) 
t= conn query (a query) 
except: 


return dumo (derault error) 
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€ Apabila hasil query merupakan 
bilangan, maka kita kembalikan 
sebagai dump dari [<hasil>, []]. 
Selain itu, kita susun hasil yang 
didapatkan sebagai seguence dari 
dictionary, dan kembalikan seba- 
gai hasil dump dari (0, «hasil su- 
sun): 


res = [| 
if ge == typetlh) or 
type(r) == type(1): 
ret = Ir 788] 
ele: 


Tora 2m re 
temp - () 
tor b in a.keys(): 
temp[b] = alb] 
res.append (temp) 
ret - [0, res] 
n 


return dump (ret) 


Contoh Client: python 


Untuk menguji dboverhttp, kita akan 
bangun satu program client dengan 
python. Program client akan meneri- 
ma sejumlah argumen, yang kemu- 
dian digabungkan dan dikirim seba- 
gai query string. Parameter koneksi 
sementara ini di-hard-code dalam 
source code. 

Di dalam direktori dboverhttp, 
kita akan membuat sample-client- 
dboverhttp.py dengan isi berikut: 

#!/usr/bin/env python 


import sys 
import Unrllib 


import yaml 


param = { 


‘elon Y ITIS S G] 
‘host’ localhost , 
OORE” ° Ol 
‘user’ ‘dboverhttp’, 
‘pw’ : ‘password’, 
‘dis? 9 “@lə@weslacitjo test” , 
Noer S25 | 
} 
tf) mame ==) iain ”s3 
Gi = ol Sy samepa [La] p) 
param['query'] = q 


# 


eparam - urllib.urlencode (param) 
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Eres = Urllab. unlepen( “http .// 


localhost:9000/query’, eparam) 


sres = fres.read() 
try: 

res = yaml.load(sres) 
esempi 

res = None 
# 
Prine "Query = ga sig) 
print ‘YAML Nrigs $ sees) 
print ‘Result: %s’ $(res[0]) 
prine Data ss 


$ (str(res[1])) 

Pastikanlah dboverhttp telah ber- 
jalan pada port 9000. Atau, sesuai- 
kanlah — sample-client-dboverhttp. 
py. Berikut adalah beberapa contoh 
query. Apabila diperlukan (misal: 
merupakan karakter spesial shell), 
bagian query/query akan diberikan 
dalam kutip. 


Versi Database 
© python Sample clicne-dbeverhetp py, 


‘select version() as v’ 
Query : select version() as v 
YAML 
= 0 
= = Yg 520,37 
Regult: 0 
Data NA ea 
Insert Data 
$ python sample-client-dboverhttp.py 
insert into test values "(1, 'a')* 
Query : insert into test values (1, 
va!) 
YAML 
= d 
= T] 
Result: 1 
bata s] 
Perhatikanlah bahwa result 


adalah 1, yang menandai affected 
rows. 


Insert Beberapa Data Sekaligus 
© Py Enon comple cliche -dboverhuup 165 


insert into test values “(2, ‘b’), 
(Bye Cin Eu cu 

Query : insert into test values (2, 
SOs) Pa Te cc xq) 

YAML 
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= Ras j feed [jin E 


nopinep-office- lx: /tap/dboverhttpi python dboverhttp. py #000 


http: AN 
127.0.0 
127.0. 
127.0 


127.0, 


D. 9000/ 
1: 4971 = [fas Mung E 13 

= [23% Jung ü l18 13: 
= = (23fJun/2016 19: 
= = [23/Jun/2011 Da 
- = [2373072030 1: 
- + [#37/Juúñn 7210 JA: 
= = (23/Jun/3014 14: 


144] 
r 14] 
7:51] 
TER 
T 
3:31] 


155] 


“HTTP? 1 
"HTTP? 
“HITPY 1. 
"HTTP/1. 
"HTTP /1. 
"HTTP/1. 
"HTTP/1. 


[E E E 
W ET ET LA Nr iL 
mom i a Km. ur 


Fi 
uN NN K. K: K 


See É sm oum 
Per K. K Oo K. 


Log server. 
= 3 
= |] 
Result: 3 
Data s | 
Update Data 


$ python sample-client-dboverhttp.py 


update test set 'a-a*2' where 'a«2' 


Query : update test set a-a*2 where 
daa 

YAML 

= d 


ST 


Result: 1 
Data c [I 


Hapus Data 
$ python sample-client-dboverhttp.py 


delete from test where ‘a<3’ 


Query : delete from test where a«3 
YAML 
= 2 
= [] 
Result: 2 
Dawa st) 
Select Data 


$ python sample-client-dboverhttp.py 
b as bbb from test 
b as bbb 


select a as aaa, 
Query : Select a as aaa, 
from test 
YAML 
2 
= = @aaas 2 
PODERE 
= daa 4 


gog Cl 


Result: 0 


Data Ieee = 3, bbb essem 


1 
1 
i 
J 
J 
J 
1 








POST / gery” 
POST fame” = 200 
POST /gquery” = 200 
POST fase” = 200 
POST fquary” - 200 
POST fqeery” - 200 
POST fgqueryg” = 200 


= £00 


Madi” g 


('aaa' : 


4, Ned 
Penjelasan 
@ Siapkan parameter koneksi: 


param - ( 


‘abn’ mysql; 

“hose: “local  , 
"DOE s (9. 

‘user’ "dboverhtbtp-^, 

‘pw’ ‘password’, 

“dlio” xdbovendctpEescs 
Vue e QU 


j 

@ Dapatkan query: 

@ = ` on , asss Liel) 
param['query'] = q 

Encode: 

eparam - urllib.urlencode (param) 

@ Kirimkan dengan Request method 
POST: 


Eres = Well lala. urlopen (“http ./ / 
localhost:9000/query', eparam) 
@ Dapatkan Respons: 


fres.read() 


€ Coba Load YAML: 


sres = 


try. 

res - yaml.load(sres) 
excep 

res - None 
# 


@ Tampilkan Query, Respons, Hasil 
Indeks 0, Hasil Indeks 1: 


print ‘Query : %s’ %(q) 
prine “YAMO \nes” 3 (sees) 
print ‘Result: %s’ %(res[0]) 
Prine “Data s g6 


sister (recs LIN) 


Sampai di sini pembahasan kita. 
Apabila diperlukan, modifikasilah se- 
suai kebutuhan. Selamat mencoba! 

Noprianto (noprianto@infolinux.co.id| 


www.infolinux.web.id 
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eragam pilihan game engine yang bersifat open source sudah tersedia di 
platform Linux. Sebut saja SDL, Cube, Blender 3D, Panda 3D, TuxCap, dan 


sebagainya. Pada artikel kali ini, kita akan membahas game engine Panda 3D 


dan TuxCap, beserta satu contoh pembuatan game sederhana. 


Membuat game bukanlah peker- 
jaan yang sederhana. Di luar alur 
permain- an itu sendiri, kita harus 
memikirkan berbagai komponen pen- 
ting berikut. Pertama, barangkali 
adalah urusan display. Apalagi ka- 
lau game yang dibangun melibatkan 
grafik 3D. Berbagai game juga akan 
lebih menarik kalau dijalankan se- 
cara full screen. Ini berarti, kita juga 
perlu menyediakannya. 

Berikutnya adalah suara. Permain- 
an tanpa suara dan efek suara tentu 
kurang menarik. Urusan suara juga 
bukan hanya sekedar memainkan 
file MP3 atau OGG. Tergantung 
game yang Anda bangun. Barangkali 
Anda juga perlu memikirkan untuk 
memainkan beberapa file suara seka- 
ligus, atau membuat suara lebih nya- 
ta ketika suatu objek mendekat. 

Setelah itu, input. Sebuah game 
tentunya melibatkan interaksi de- 
ngan pemain. Baik melalui keyboard, 
mouse ataupun perangkat input lain- 
nya. Semuanya harus ditangani de- 
ngan baik. Apabila Anda membangun 
game pertarungan, dimana jurus 
dikeluarkan berdasarkan rangkaian 
input keyboard dengan perhitungan 
waktu, maka urusan input menjadi 
lebih penting lagi. 

Berikutnya, jangan lupakan juga 
soal networking. Game yang Anda 
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bangun mungkin mendukung mul- 
tiplayer lewat Internet. Ini berarti, 
masalah koneksi, protokol dan opti- 
masi harus dipikirkan dengan sung- 
guh-sungguh. Terutama ketika para 
pemain berada di dalam jaringan 
yang tidak selalu stabil. 

Dalam suatu permainan, umum- 
nya kita perlu memberikan opsi 
kepada user, sebagai contoh untuk 
mengatur volume suara, full screen/ 
windowed atau opsi lainnya, di te- 
ngah-tengah permainan. Ini tidak 
bisa selalu diberikan sebagai argu- 
men ketika menjalankan program. 
Program harus mendukung graphical 
user interface yang umum dan mudah 
digunakan oleh user. Dan sebaiknya, 
jangan sampai GUI dibangun dengan 
menggambar dan memroses input se- 
cara manual. 

Jangan lupa juga bahwa teknik 
pemrograman seperti multi-thread- 
ing sangatlah penting untuk diterap- 
kan dalam pengembangan game. 
Ketika Anda sibuk merespons input 
dari pemain, di saat bersamaan Anda 
harus mengirim data lewat jaringan. 
Di saat bersamaan juga, Anda harus 
menangani objek lain di dalam game. 
Jangan lupa, suara juga harus di- 
mainkan. 

Agar lebih realistis dan nyaman 
dimainkan, libatkan juga berbagai 


algoritma khusus game. Sebagai 
contoh, tubrukan antarobjek. Pada 
permainan yang melibatkan banyak 
objek yang saling berinteraksi, kita 
perlu memikirkan agar objek satu 
dan lainnya, ketika bertubrukan 
dapat melakukan tindakan tertentu. 
Sebagai contoh, ketika sebuah objek 
berhadapan dengan dinding, maka 
tidak bisa dilewati. 

Contoh penerapan ilmu fisika. 
Suatu objek yang jatuh dari atas, 
semakin ke bawah, harus semakin 
cepat. Ketika tubrukan terjadi pada 
saat jatuh, maka efek yang terjadi 
harusnya tidak sama dengan tubruk- 
an pelan antardua objek. Hitung-hi- 
tungan seperti ini sangatlah penting. 

Berikutnya, walaupun tampak se- 
derhana, kita perlu juga memikirkan 
fungsi-fungsi pelengkap pada game. 
Seperti bekerja dengan filesystem, 
menyimpan ke database, dan lain se- 
bagainya. Jangan sampai pesan kesa- 
lahan muncul atau game menjadi 
crash, hanya karena mencoba menu- 
lis ke file dimana kita tidak memiliki 
hak. 

Urusan kecerdasan buatan juga 
sangat penting. Sebagai contoh, pada 
game pertarungan antara pemain la- 
wan CPU, maka lawan harus cukup 
tangguh dalam bertarung. Ketika 
level semakin tinggi, maka lawan 
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juga mungkin harus lebih pintar 
lagi. 

Apabila Anda ingin agar pemain 
bisa melakukan kustomisasi/prog- 
ramming sederhana pada game, maka 
mungkin Anda ingin menyediakan 
fasilitas scripting yang semudah 
mungkin. Anda dapat menggunakan 
python atau lua, misalnya. 

Anda bisa bayangkan, kalau ber- 
bagaiaspektersebut harus kita usaha- 
kan sendiri. Jangan lupa juga kalau 
game yang kita bangun ada baiknya 
untuk dapat berjalan pada beberapa 
sistem operasi. Ini menjadikan pena- 
nganan low level seperti display dan 
suara lebih susah. 

Memang, Anda bisa menggunakan 
SDL untuk tampilan, suara, jaringan, 
dan lainnya. Anda bisa mengombi- 
nasikan dengan pustaka untuk pene- 
rapan ilmu fisika. Anda bisa meng- 
gunakan pustaka GUI khusus game. 
Dan pustaka-pustaka lepas lainnya. 
Tapi, mengombinasikan satu per satu 
proyek yang dikembangkan dengan 
irama yang berbeda, dengan tujuan 
spesifik yang mungkin berbeda pula, 
bukanlah pekerjaan yang nyaman. 

Di sinilah game engine hadir. 
Satu pustaka lengkap dan terinte- 
grasi yang siap mendukung Anda 
untuk membangun game. Urusan 
multi-platform, jangan dipikir lagi. 
Komponen-komponen penting seper- 
ti dibahas sebelumnya juga sudah 
siap. Bahkan, kadang disertai de- 
ngan contoh game siap main, dimana 
Anda bisa mengagumi betapa dengan 
source code yang relatif pendek, 
menghasilkan game yang begitu luar 
biasa. 

Game engine super canggih biasa- 
nya dapat ditemukan di dunia pro- 
prietary. Ini sangat lumrah karena 
game engine dapat dilisensikan ke 
perusahaan pengembang game lain- 
nya, dimana produk akhirnya dapat 
dijual cukup mahal secara massal. 
Melisensikan game engine umumnya 
memberikan pemasukan yang sangat 
menggiurkan. Apalagi, jika suatu 
game engine telah terbukti dapat di- 
gunakan untuk membuat game yang 
populer. 
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Untungnya, para developer free/ 
open source software juga tidak ting- 
gal diam. Sebagai hasilnya, terdapat 
puluhan game engine yang bisa kita 
gunakan. Beberapa sangat bagus, 
lengkap dan stabil. Hebatnya lagi, 
cukup banyak game engine yang 
dilisensikan dengan sangat bebas: 
BSD, MIT atau paling tidak, LGPL. 
Dengan demikian, dapat pula diguna- 
kan untuk membangun game proprie- 
tary. 

Salah satu game engine yang akan 
kita bahas di dalam tulisan ini adalah 
Panda3D. Tidak tanggung-tanggung, 
game engine ini dikembangkan awal- 
nya oleh Disney, untuk kepentingan 
pembuatan game komersial. Game 
engine ini dapat digunakan untuk 
membangun game 3D. 

Contoh lain yang juga cukup me- 
narik adalah TuxCap. Engine ini 
merupakan port dari framework 
game PopCap yang cukup terkenal di 
dunia Windows. 

Kedua engine tersebut menguna- 
kan lisensi BSD yang sangat bebas. 

Untuk daftar game engine free/ 
open source lainnya, Anda mungkin 
ingin membaca di situs http://gpwi- 
ki.org/index.php/Game Engines dan 
http://en.wikipedia.org/wiki/List | 
of game, engines. Sangat banyak ter- 
sedia, walau dengan kematangan/fi- 
tur yang juga sangat beragam. 

Untuk kedua game engine yang 
dibahas, kita akan mulai dari kom- 
pilasi. Kita tidak melakukan insta- 
lasi system wide, agar sistem tidak 
menjadi kotor selama kita menguji. 
Setelah itu, kita akan memastikan 
bahwa game engine telah terinstal 
dengan baik. Caranya, dengan men- 
jalankan contoh game yang diser- 
takan. Pada akhir tulisan, barulah 
kita membahas satu contoh sangat 
sederhana penggunaan game engine 
Panda3D. 

Semua contoh dibangun di atas 
Singkong Linux 1.0 (noprianto.com), 
namun dapat diterapkan pada sistem 
lainnya. 

Tulisan ini lebih dimaksudkan 
sebagai pengenalan. Untuk contoh 
game yang dibangun dengan pustaka 
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free/open source juga (pygame), bisa 
dibaca pada InfoLINUX 08/2006. 


Panda3D 


Dibangun oleh Disney untuk kepen- 
tingan pembuatan game komersial, 
sampai saat ini pengguna utama 
game engine ini tetaplah developer 
game komersial. Jadi, Anda bisa ba- 
yangkan kualitas yang harus dimiliki 
oleh Panda3D. 

Ada empat area dimana menjadi 
perhatian: power, speed, complete- 
ness dan error tolerance. Sebagai 
hasilnya, Panda3D datang dengan 
fitur yang lengkap, stabil, dan power- 
ful. 

Saat ini, Panda3D dikembang- 
kan oleh Disney dan Entertainment 
Technology Center Carnegie Mellon 
University. 

Dari sisi dukungan bahasa pem- 
rograman, Panda3D sangat mena- 
rik (setidaknya bagi penulis). En- 
gine yang membutuhkan performa 
tinggi, dikembangkan dengan C++. 
Namun, untuk pengembangan game 
dapat menggunakan python atau 
C++. Salah satu tujuan utama engine 
adalah mendukung python. Jadi, 
mengikuti filosofi: Python where we 
can, C++ where we must :). 

Dokumentasi yang tersedia juga 
sangat lengkap, nyaman dibaca, dan 
dilengkapi contoh (untuk python dan 
C++). 

Pada saat tulisan ini dibuat, versi 
terbaru Panda3D adalah 1.7.0 (un- 
stable, experimental). Kita akan 
menggunakan versi ini. Untuk in- 
formasi selengkapnya, kunjungilah: 
http://www.panda3d.org. 


Instalasi 
1. Download-lah source code SDK 
versi 1.7.0 dengan perintah beri- 
kut. File yang akan kita download 
berukuran 34 MB: 
wget http://www.panda3d.org/ 
download/panda3d-1.7.0/panda3d- 
qe Vo Os CEE GZ 
2. Ekstrak dan masuk ke direktori 
hasil ekstrak: 
$ car mavi pewdasd-L, 7,0, tar.gz 
Š cd pandasd—l.7.0 
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Kita akan sebut direktori aktif se- seperti berikut: $ cd samples/ 

bagai «root source panda». [ 98%] Compressing built/models/ Pilihlah satu contoh untuk di- 
3. Lakukan kompilasi dengan perin- shuttle controls.egg.pz jalankan (misal: Boxing-Robots): 

tah berikut. Pastikan python telah built/models/shuttle controls. $ cd Boxing-Robots/ 

terinstal. Berikan Opsi --help un- egg.pz S python Tut-Boxing-Robots.py 

tuk opsi selengkapnya. Kita harus [ 99$] Compressing built/models/ 

cukup bersabar. Di sistem penulis, smiley.egg.pz Catatan: 

proses ini memakan waktu satu built/models/smiley.egg.pz € apabila Anda menjumpai pesan- 

jam lebih sedikit: [ 99$] Compressing built/models/ pesan kesalahan berikut, maka 


$ python makepanda/makepanda.py 
==no-Limpeg 

Generating library cache... 
WARNING: Could not locate 
thirdparty package artoolkit, 
excluding from build 
WARNING: Could not locate 
thirdparty package fcollada, 
excluding from build 
WARNING: Could not locate 
thirdparty package fftw, 
excluding from build 
WARNING: Could not locate 


thirdparty package fmodex, 


ir elo egg IO 
built/models/teapot.egg.pz 
[ 99$] Compressing built/models/ 
yup-axis.egg.pz 
built/models/yup-axis.egg.pz 
[ 99$] Compressing built/models/ 
zup-axis.egg.pz 
built/models/zup-axis.egg.pz 
Storing dependency cache. 
Build successfully finished, 
elapsed time: 1 hours 3 min 
5. Selesai kompilasi dilakukan, akan 

terbentuk direktori built: 

Š ls = loma lif 


pastikan PYTHONPATH telah 
diset dengan benar: 
S python Tut-Boxing-Robots.py 
Traceback (most recent call 
Jag) 3 
File “Tuc-Boxing-Robotspy”, 
line 7, in «module» 
import direct.directbase. 
DirectStart 
ImportError: No module named 


direct.directbase.DirectStart 


S python Tut-Boxing-Robots.py 
DirectStart: Starting the game. 


excluding from build LICENSE Traceback (most recent call 
WARNING: Could not locate ReleaseNotes last) s 

thirdparty package nvidiacg, ban/ pile “lut=Boxind-Rebots py”, 
excluding from build direct/ line 7, in <module> 

WARNING: Could not locate etc/ import direct.directbase. 
thirdparty package ode, excluding include/ DirectStart 

trom build Tab File “/tmp/A/panda3d-1.7.0/ 
WARNING: Could not locate models/ built/direct/directbase/ 
thirdparty package opencv, pandac/ DymectStart.py", line 3, an 
excluding from build plugins/ «modules 

WARNING: Could not locate tmp/ from direct.showbase import 


thirdparty package squish, 
excluding from build 

WARNING: Could not locate 
thirdparty package vrpn, 
excluding from build 

WARNING: Could not locate 
thirdparty package tinyxml, 
excluding from build 

Generating dependencies... 

[ 0%] Building C++ object built/ 
tmp/dtoolbase compositel.o 

[ 0%] Building C++ object built/ 
tmp/dtoolbase composite2.0 

IL 0b] Building € object lama, t 
tmp/dtoolbase lookup3.o 

[ 0$] Building C++ object built/ 


tmp/dtoolbase indent.o 


Menjalankan Sample 
Karena tidak melakukan instalasi 
system wide, maka kita perlu meng- 
atur LD LIBRARY PATH dan PY- 
THONPATH: 
$ export LD LIBRARY PATH-«root 
source panda>/built/lib 
S Export PYTHONPATH=<root source | 
panda»/built:«root source panda>/ 
built/lib/ 

Contoh apabila root source code 
panda3d adalah: /tmp/A/panda3d- 
1.7.0: 

$ export LD LIBRARY PATH-/tmp/A/ 
panda3d-1.7.0/built/lib/ 

$ export PYTHONPATH-/tmp/A/panda3d- 
1.7.0/built:/tmp/A/panda3d-1.7.0/ 
built/lib/ 


ShowBase 
File "/tmp/A/panda3d-1.7.0/ 
built/direct/showbase/ShowBase. 
py”, line 14, in «module» 
_ builtin .contg = 
getConfigShowbase () 
NameError: name 
‘getConfigShowbase’ is not defined 
€ Atau apabila pesan yang dijumpai 
adalah sebagai berikut, maka pas- 
tikan LD_LIBRARY_PATH telah 
diset dengan benar: 
S python Tut-Boxing-Robots.py 
DirectStart: Starting the game. 
Traceback (most recent call 
Tae 
File “Tut-Boxing-Robots.py", 
line 7, in «module» 


import direct.directbase. 


4. Pada akhir kompilasi yang sukses, Masuklah ke dalam direktori sam- DirectStart 
Anda akan mendapatkan pesan | ples: File "/tmp/A/panda3d-1.7.0/ 
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built/direct/directbase/ 
Drrectstart.py". line 32) an 
<module> 

from direct.showbase import 
ShowBase 

File “/tmp/A/panda3d-1.7.0/ 
built/direct/showbase/ShowBase. 
py”, line 10, in <module> 

from pandac.PandaModules 
import * 

File “/tmp/A/panda3d-1.7.0/ 
built/pandac/PandaModules.py", 
line 2, in «module» 

from libpandaexpressModules 
Saga ° 

File “/tmp/A/panda3d- 

157 0/built/pandac/ 
libpandaexpressModules.py", line 
1, in «module» 

TON ektengion native helperg 
impost * 

File "/tmp/A/panda3d-1.7.0/ 
built/pandac/extension native 
helpers.py", line 81, in <module> 

Drool PrelloadDil  !wbpandaex 
press”) 

File “/tmp/A/panda3d-1.7.0/ 
built/pandac/extension native 
helper pi line 79, im Deal 
PreloadDLL 

imp.load dynamic (module, 
pathname) 
impobsthrror- 01553dto900 50: 
cannot open shared object file: No 


such file or directory 


TuxCap 

Anda ingin membangun game 2D 
yang menarik seperti game PopCap 
di Windows. Anda ingin membangun 
dengan bahasa python. Anda ingin 
dukungan penerapan ilmu fisika. 
Anda dapat menggunakan TuxCap 
(http://sourceforge.net/projects/tux- 
cap). 

Pada saat tulisan ini dibuat, versi 
terbaru adalah 1.4.0. Sayangnya, 
percobaan kompilasi yang penulis 
lakukan selalu gagal. Penulis kemu- 
dian berhasil dengan versi dari CVS. 

Untuk men-download versi 1.4.0, 
Anda dapat mengunjungi: http:// 
sourceforge.net/projects/tuxcap/ 
files/tuxcap/libtuxcap-1.4.0/lib- 
tuxcap-1.4.0.tar.gz/download. Un- 
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tuk men-donwload tarball dari 
CVS, kunjungilah:  http://tuxcap. 
cvs.sourceforge.net/viewvc/tuxcap/ 
?viewz-tar. 


Instalasi 
]. Ekstraklah arsip dan masuklah ke 
direktori hasil ekstrak: 
Stan Ku tuxcep Ear GZ 
S dd tuxcap/ kap 
2. Lakukanlah konfigurasi dengan 
perintah berikut. Anda membu- 
tuhkan cmake terinstal di sistem. 
Di Singkong Linux, cmake telah 
terinstal secara default: 
$ cd tuxcap-build/ 
S cmake 
-- Check for working C compiler: 
"usu bus ce 
== Check tor working C compiler: 
/usr/bin/gcc -- works 
== Check size of void* 
-- Check size of void* - done 
== Check for working CXX 
compiler: /usr/bin/c++ 
== Check for working CXX 


compiler: /usr/bin/c++ -- works 


== Contiguring done 
-- Generating done 
-- Build files have been written 


to: /tmp/A/tuxcap/TuxCap/tuxcap- 


build 
3. Lakukanlah kompilasi dengan 
perintah berikut: 
S make 


Scanning dependencies of target 
Uk 

[ 5] Butiding CO object 
tuxcap/lib/CMakeFiles/tuxcap. 
dus Ratio Oo 

IL isl balela) C object 
tuxcap/lib/CMakeFiles/tuxcap. 
dir/Buffer.o 

L 2%] Butiding CO object 
tuxcap/lib/CMakeFiles/tuxcap. 
dir/SexyAppBase.o 


4. Apabila kompilasi sukses, Anda 
akan menjumpai pesan berikut: 
[| 995] Bulling Cxx object 


tuxcap/hungarr/CMakeFiles/../../ 
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Contoh tampilan game yang kita kembangkan. 


Hungarr.dir/GameApp.o 
[100%] Building CXX object 
tuxcap/hungarr/CMakeFiles/../../ 
Hungarr.dir/Res.o 
Linking CXX executable ../../ 
Hungarr 
[100$] Built target ../../Hungarr 
Menjalankan Sample 
Masih di dalam direktori aktif, Anda 
bisa menjalankan: 
€ demo *. 
€ Physicsdemo*. 
@ Hungarr -» menarik. 
€ pythondemol dan pythondemo2. 
Masuklah terlebih dahulu ke 
dalam direktori pythondemol 
atau pythondemo2 untuk men- 
jalankan contoh: 
$ cd pythondemol 
$ ./Pythondemol 


Contoh Sederhana 

Dalam dokumentasi Panda 3D, ter- 
dapat tutorial langkah demi lang- 
kah yang cukup jelas untuk memu- 
lai pemrograman game. Hasil dari 
tutorial tersebut adalah panda yang 
berjalan maju mundur, di tengah 
background tertentu, dengan kamera 
memutari. Selengkapnya, Anda bisa 
membaca di http://www.panda3d. 
org/wiki/index.php/A_Panda3D_ 
Hello_World_Tutorial. 

Penulis kemudian mengikuti tu- 
torial tersebut, namun tidak sampai 
panda berjalan maju mundur. Hanya 
sampai panda berjalan di tempat 
saja :) Kemudian, penulis membaca 
source code Boxing Robots dan do- 
kumentasi, dan mencoba menam- 
bahkan penekanan tombol keyboard. 
Sebagai hasilnya, penekanan a dan s 
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akan menyebabkan panda berpindah 
posisi secara tiba-tiba, penekanan 
d akan membuat panda membesar, 
penekanan f akan membuat ukuran 
panda normal kembali dan escape 
akan mengakhiri program. 

Contoh yang dibahas di dalam 
tulisan ini masih sangat sederhana. 
Penulis masih berusaha mempelajari 
Panda 3D. Sungguh menarik mem- 
buat game dengan Panda 3D. 

Kita akan menggunakan file-file 
yang datang bersama distribusi Pan- 
da 3D, yaitu: 
€ «root source panda»/models/en- 

vironment.egg. 
€ «root source panda»/models/ 

panda-model.egg. 
€ «root source panda»/models/ 
panda-walk4.egg. 


File-file tersebut dibuat dengan 
3D modelling program, seperti Maya, 
Max atau Blender, dan kemudian 
diekspor ke egg. Sebuah file egg bisa 
mengandung: 

@ Model (statik). 

@ Aktor (dinamik). 

@ Animasi (diaplikasikan ke aktor). 
@ Aktor dan animasi. 


Kita akan siapkan sebuah direk- 
tori, dimana ketiga file egg tersebut 
kita kopikan ke dalamnya. Di dalam 
direktori tersebut, kita buat test.py 
dengan isi sebagai berikut: 

#!/usr/bin/env python 


#versi lebih sederhana dari tutorial 
Panda3D 

http: //www.panda3d.org/wiki/index. 
php/A Panda3D Hello World Tutorial 

H 

#yang dilengkapi penekanan tombol 

H 


import sys 

tron marta imoore pa, sin, cos 

from direct.showbase.ShowBase import 
ShowBase 

from direct.task import Task 


From direct actor, Actor import Actor 


class MyApp (ShowBase ) : 
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det _ imit (sel) s 


Showbdse imit Seit) 


self.environ - self.loader. 
loadModel (‘./environment’ ) 
self.environ.reparentTo (self. 


render) 


self.environ.setScale(0.25, 
0.25, 0.25) 


self.environ.setPos(-8, 42, 0) 


self.taskMgr.add(self. 


spinCameraTask, "SpinCameraTask") 


self.actor - Actor('panda- 


model', 


‘walk’: ‘panda-walk4’, 


) 
self.actor.setScale(0.005, 
0.005, 0.005) 
self.actor.setPos(0, 0, 0) 
self.actor.reparentTo(self. 
render) 


self.actor.loop('walk') 


self.accept (‘escape’, sys.exit) 
self eccept l'a’, eelt move 1) 
gelf accept (s, eelt move 2) 
self accept (d, eelt seale l) 


self accept (E, eelt scale 2) 


def spinCameraTask (self, task): 

angle deg = task time * 6.0 

angle_rad = angle_deg * (pi / 
180.0) 

self.camera.setPos(20 * 
Sant (angle racl), -20.0 > coslangle 
cac), 3) 

seli camera germe (lengle ceg, 
©, ©) 


return Task.cont 


der move elu 


self.actor.setPos(-1, 0, 0) 


det move ste bre 


self.actor.setPos(1, 0, 0) 


det scale (sellin) s 
self.actor.setScale(0.010, 
DET STO 


det scale Aas 
self.actor.setScale(0.005, 
0.005, 0-005) 


if | name == ' main ': 

app - MyApp() 

app.run() 

Setelah itu, jalankanlah dengan 
perintah berikut (aturlah LD LIB- 
RARY PATH dan PYTHONPATH 
seperlunya): 

S python test.py 

Penjelasan, penulis kutip dari 
tutorial Panda 3D, sebisa mungkin 
penulis pahami: 

@ Kita buat sebuah class, turunkan 
dari ShowBase. Berbagai modul 
Panda 3D akan di-load, dan me- 
nyebabkan window 3D tampil. 
Method run() akan menjalankan 
main loop. 

€ Dengan loader.loadModel(), kita 
load sebuah model (environment. 
egg). Kita render dengan melaku- 
kan reparent ke objek render: 

self .environ = self.loader. 
loadModel("'./environment') 

self.environ.reparentTo(self. 
render) 

@ Kemudian, kita atur skala dan po- 
Sisl: 

self.environ.setScale(0.25, 
0225 MEDI 
self.environ.setPos(-8, 42, 0) 

@ Kita kemudian membuat kamera 
berputar dengan membuat sebuah 
task. Task adalah fungsi yang akan 
dijalankan setiap frame oleh task 
manager. Dalam fungsi tersebut, 
kita kembalikan Task.cont agar 
tetap dipanggil. Di dalam fungsi 
spinCameraTask(): 

e Kamera berputar 6 derajat se- 

tiap detik. 

e method setPos() digunakan un- 

tuk mengatur posisi kamera. 

e method setHpr() digunakan un- 

tuk mengatur orientasi: 


From Math Impose pi sin, cos 


from direct.task import Task 


self .taskMgr.add (self. 
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SpinCameraTask, "SpinCameraTask") 


def spinCameraTask(self, task): 
engle deg = task. Gime * 6.0 
angle rad = angle deg * (pi / 
160.0) 
self.camera.setPos(20 
= ginlangle rac), -20.0 * 
Cos (amale ad), 3) 
self camera gethpr lengle deg, 
0) 
recura PCR eC 
€ Setelah itu, kita load aktor panda- 
model, dengan definisi key walk 
mengacu kepada animasi panda- 
walk4: 


Lom direct getor Actor 1Impost 


Actor 


self.actor = Actor('panda- 


model', 


{ 


‘walk’: 'panda-walk4', 


dijaminmurah 
hoatimg Indonesia rermurah 
HUBUNGI KAMI : 

Phone 


(021) 
FAX (021) 53154913 
emad : 


salesipdiaminmurah com 


) 

Kemudian, kita atur skala dan po- 
sisi aktor: 

self.actor.setScale(0.005, 0.005, 

0.005) 

self.actor.setPos(0, 0, 0) 
Lakukan render aktor dengan re- 
parent ke objek render: 


self.actor.reparentTo(self. 


render) 
Lakukan looping animasi key walk, 
yang didefinisikan sebelumnya: 


selt actor loop walk") 
Kita tambahkan penekanan tom- 
bol: 


import sys 


.accept ('escape', sys. 


“accepu a selit mova 1) 
GESENG, Selt mova 2) 
saga d, selt. scale 1) 


ACCEPE LE”, selt. scale 2) 
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Untuk mengatur posisi, kita 

gunakan setPos() seperti contoh 

sebelumnya. Demikian juga peng- 

aturan skala dengan setScale(): 
det move 1 (self) s 


self.actor.setPos(-1 


det move 2 (selt) s 


self.actor.setPos(1, 0, 0) 


det scale buscas 
self.actor.setScale(0.010, 
0.010, 0.010) 


det scale 2 (Seli) s 
self.actor.setScale(0.005, 
0.005, 0.005) 


Sampai di sini pembahasan kita. 
Untuk mempelajari lebih lanjut þe- 
ragam fitur yang terdapat di Panda 
3D, Anda dapat mengakses ke url 
http://www.panda3d.org/documen- 
tation.php. 

Semoga Anda dapat menjadi pem- 
buat game yang terkenal!" 

Noprianto (noprianto@infolinux.co.id| 
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Ada sebuah cerita. Sepuluh tahun 
yang lalu, sebuah perusahaan memu- 
tuskan untuk mulai lebih serius 
menggunakan teknologi informasi. 
Komputer mulai diadakan di setiap 
kantor cabang yang tersebar di Indo- 
nesia. Peraturan baru pun mengikuti: 
setiap data penjualan mulai saat itu 
harus dilaporkan ke pusat setiap 
minggunya. Secara berkala, setiap 
minggu data di-entri ke spreadsheet, 
kemudian di e-mail ke pusat. Di pu- 
sat, tim TI akan mengopikan data 
yang didapat, kemudian dengan be- 
berapa program yang telah dibangun, 
akan membuat laporan dan analisis 
sederhana. 

Tidak terasa, proses ini berlang- 
sung terus menerus dan menjadi 
kebiasaan. Di tengah perjalanan, se- 
benarnya ada keinginan untuk mem- 
bangun aplikasi terintegrasi, dimana 
setiap cabang dapat login dan meng- 
isikan data secara langsung. Tapi, 
apa boleh buat. Perusahaan saat itu 
harus lebih fokus ke urusan lain yang 
lebih penting. Urusan data, selama 
bisa sampai, sementara tidak di- 
ubah dulu. Selain itu, pengembangan 
sistem juga pasti membutuhkan bia- 
ya dan perhatian yang tidak sedikit. 
Apalagi, di kantor cabang semua su- 
dah sangat terbiasa. Migrasi sedikit 
banyak akan mengganggu. Manaje- 
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men memutuskan: jalan terus dengan 
apa yang ada. 

Perusahaan semakin membesar 
dan cara manual sudah tidak dapat 
lagi diandalkan. Manajemen ingin 
laporan yang lebih cepat setiap saat. 
Harus ada yang diubah, tapi tidak 
bisa semua sekaligus. Akhirnya, 
diputuskan untuk memperkuat da- 
tabase terlebih dahulu. Database 
system yang dipilih adalah MySQL. 
Semua data dalam spreadsheet yang 
diterima, secara otomatis harus di- 
masukkan ke MySQL server. Setelah 
urusan yang satu ini lancar, migrasi 
dan pengembangan lebih lanjut bisa 
dilakukan. Sampai di sini, cerita se- 
lesai. 

Pada InfoLINUX 07/2010, telah 
membahas dasar-dasar otomatisa- 
si OpenOffice.org dengan python 
dengan beberapa contoh, termasuk 
membuat spreadsheet dan mengon- 
versi dokumen ke PDF atau format- 
format lainnya (bacalah apabila di- 
perlukan). Yang kita butuhkan saat 
ini hanyalah mendapatkan data dari 
spreadsheet, melakukan koneksi ke 
database, dan mengirimkan guery 
untuk menambahkan data. 

OpenOffice.org yang diguna- 
kan dalam tulisan ini adalah versi 
2.3.0, yang disertakan dalam Sing- 
kong Linux Extra (noprianto.com). 


nda menerima laporan dalam format spreadsheet. Sementara, semua data 
harus disimpan dalam MySQL server. Dengan menggunakan OpenOffice.org 
dan python, kita akan ekstrak data dari spreadsheet dan menyimpannya ke 
MySQL. Apabila diperlukan, kita juga bisa melakukan sebaliknya. 


Sayangnya, python 2.3.4 yang datang 
bersama OpenOffice.org tersebut ti- 
dak disertai dengan modul untuk 
bekerja dengan MySQL (MySQLdb). 
Sementara, kompilasi/instalasi se- 
pertinya cukup merepotkan. Modul 
yang dibangun dengan python mur- 
ni, kalaupun ada/layak pakai, juga 
tidak bisa digunakan karena mem- 
butuhkan python dengan versi lebih 
tinggi. 

Oleh karena itu, untuk bekerja 
dengan database, kita akan menggu- 
nakan dboverhttp (bacalah tulisan: 
Mengakses database MySQL lewat 
HTTP di edisi ini). Dengan menggu- 
nakan proyek ini, kita dapat bekerja 
dengan MySQL lewat HTTP saja. Ti- 
dak perlu modul MySQLdb. Cukup 
urllib saja. 

Semua program dibangun dengan 
python dan dilisensikan GPL. 


Aturan Spreadsheet 

Dalam tulisan ini, kita akan meng- 

gunakan spreadsheet dengan aturan 

berikut: 

€ Tanpa pemformatan dan tanpa 
judul. 

€ Laporan dimulai dari Al, hanya 
pada sheet1. 

€ Laporan selalu terdiri dari dua 
kolom: A dan B. 

@ Kolom A merupakan ID produk. 
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@ Kolom B merupakan jumlah ter- 
jual. 


Contoh: 





Sebagai contoh, data akan disim- 
pan sebagai a.ods. 


Struktur Database 


Kita akan siapkan sebuah data- 
base untuk menampung data dari 
spreadsheet. Sebagai root MySQL, 
buatlah database spreadsheet dan 
berikanlah hak penuh kepada 
spreadsheet@localhost, dengan pass- 
word: password: 

guysgüécseredgecadagueabuscesporeadsheer 


Query OK, 1 row affected (0.01 sec) 


mysql» grant all privileges 

on spreadsheet.“ to 
spreadsheet@localhost identified by 
‘password’ ; 


Query OK, 0 rows affected (0.00 sec) 


mysql» flush privileges; 
Query OK, 0 rows affected (0.00 sec) 
Kemudian, sebagai user 
spreadsheet@localhost, buatlah tabel 
berikut: 
me l> Use sp redd sheet, 


Database changed 
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mysql» create table test (id 
varchar(8), qty integer); 


Query OK, 0 rows affected (0.01 sec) 


mysaile dese TeSt, 


+------- +------------ +------ +----- +- 
-------- +-------+ 

| Field | Type | Null | Key | 
Default | Extra | 

+------- +------------ +------ +----- +- 
-------- +-------+ 

| dd | varchar(8) | YES | | 
NULL | | 

la ai) | vas | | 
NULL | | 

+------- +------------ +------ +----- +- 


2 rows in set (0.01 sec) 


Menjalankan OpenOffice.org sebagai 
Server 
Untuk semua contoh yang dibahas 
di dalam tulisan ini, OpenOffice.org 
harus dijalankan terlebih dahulu se- 
bagai server. Agar dapat diterapkan 
pada lingkungan server tanpa GUI, 
maka OpenOffice.org dijalankan de- 
ngan opsi -headless. 
Jalankanlah OpenOffice.org de- 
ngan cara berikut: 
«PREFIX OOO»/program/soffice - 
headless -accept="socket,host=localh 
Ost, POort=<PORTS, urp" 
Contoh: 
/opt/openoffice.org2.3/program/soffice 
-headless -accept-"socket,host-local 


NOST, pone—s000 Ep 


Fu [ur vee frome daaa foe Heg 
m E4 I Tem 








= | want 1o learn more abdul OpenOffice. org 


TE fe Pai Ad A | Ri 





4n | want to download OpenOffice.org 


-— 


T PEN eee s s? 


Situs web OpenOffice.org. 
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Crue Ha mcr) 17 x ee 


Surmar Irene 
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Pe DusscEMS qu mui Be 
Papa ngi tees keng je 


THO 060 ODO downloade 
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Ketika perintah tersebut dijalan- 
kan, tidak ada GUI yang dijalankan. 
Program akan berjalan di foreground. 
Port yang dipergunakan adalah 8000. 
Untuk melakukan terminasi, tekan- 
lah Ctrl-C. 


Gunakan Python dari OpenOffice.org 
Kita akan menggunakan python yang 
datang bersama OpenOffice.org. 
Tersedia script untuk mempermu- 
dah kita dalam menjalankan python, 
yaitu: <PREFIX_OOO>/program/py- 
thon: 
$ /opt/openoffice.org2.3/program/ 
python 
Python 2.3.4 (#1, Aug 8 2007, 
18:47:03) 
[GCG 3.4.1] on Limusa 
type “help”, “copyright”, “esedits” 
or “license” for more information. 
>>> 
Dengan demikian, ketika men- 
jalankan program yang dibuat, kita 
perlu memberikan perintah: 
«PREFIX 000>/program/python 
<program.py> 
Contoh: 
/opt/openoffice.org2.3/program/python 
programl.py 


Mendapatkan Data Spreadsheet 
Dalam contoh create-ods.py di edisi 
07/2010, kita menambahkan data di 
sel dengan setString(). Kali ini, kita 
melakukan sebaliknya, dengan get- 
String(). Tinggalmelakukanperulang- 
an: selama data masih ditemukan, 
kita proses. 

Berikut adalah source code read_ 
spreadsheet.py: 


#(c) Noprianto, GPL 


import sys 

import os 

" 

Ir. 
import uno 

except ImpobtBrtror ce: 
print e 


Sys.exit (2) 


def main(infile): 


" 
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uctx - uno.getComponentContext () 

resolv - uctx.ServiceManager. 
createInstanceWithContext ('com.sun. 
star.bridge.UnoUrlResolver', uctx) 

ctx = resolv.resolve(‘uno: 
socket, host—localhost, porte—s000;urp, 


StarOffice. Component Context ' ) 


# 

smgr = ctx.ServiceManager 

desktop = smgr.createInstance 
WithContext (‘com.sun.star.frame. 


Desktop”, etx) 


# 
Inul = Une. 
systemPathToFileUrl (os.path. 
abspath (infile) ) 
doc = desktop. loadComponentFromU 


RI inurl = blank’), 0, (0) 


# 
sheet = doc.getSheets(). 
getByIndex(0) 
qc 
while True: 
a hec 
getCellByPosition(0, i).getString() 
D = @le@ . 
getCellByPosition(1, i).getString() 
if not a: break 
pront as 5 


i+= 1 


# 
doc.close (True) 


return True 


L a gys arc L] 
except IndexError: 

print ‘usages $9 cinputs ` 

$ (sys.argv [0] ) 

elses 

ake mala: 

ret - 0 

# 
sys.exit (ret) 

Pastikanlah server OpenOffice.org 
telah dijalankan. Berikanlah perin- 
tah berikut untuk mendapatkan data 
dari spreadsheet. 

«PREFIX OOO»/program/python read 
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spreadsheet.py «input» 


$ /opt/openoffice.org2.3/program/ 
pyehon “ead spreadshece. py =ë oss 
A01 10 
A02 20 
A03 40 
A04 70 


Penjelasan: 

@ Apabila diperlukan, bacalah tu- 
lisan otomatisasi OpenOffice.org 
di edisi 07/2010. 

@ Yang penting dalam contoh ini 
adalah: 
e Dapatkan 


(sheet1): 
sheet = doc.getSheets (). 


sheet pertama 


getByIndex (0) 
e Ulang selama baris di kolom A 
masih terdapat data: 
L= 0 
while True: 
a = sheet. 
getCellByPosition(0, 
i) .getString () 
b = sheet. 
getCellByPosition(1, 
1) getstring ( ) 
if not a: break 
e Data tersebut kemudian kita 
tampilkan: 
print A, l9 


ar 


Memasukkan Data yang Didapat ke 
MySQL 
Data spreadsheet sudah kita dapat- 
kan. Berikutnya, kita akan menyim- 
pannya ke MySQL. Contoh beri- 
kut, spreadsheet db.py merupakan 
kombinasi dari contoh sebelumnya 
(read, spreadsheet.py) dan sample- 
client-dboverhttp.py (contoh client 
dboverhttp). Pastikan modul PyY- 
AML telah terinstal. 
Berikut adalah 
spreadsheet db.py: 


source code 
#(c) Noprianto, GPL 

import sys 

import os 

Ingat wired Ii 

import yaml 

# 

Ey. 


import uno 
except MBOK, D 
print e 


sys.exit (2) 


H 

param = { 
“alba emg 
POSEK iocus 
EDGE ANO 
‘user’ ‘spreadsheet’, 
‘pw’ MISS wona, 
“db : ‘spreadsheet’, 
Noel Te 


j 


def main (infile): 
# 
uctx - uno.getComponentContext () 
resolv - uctx.ServiceManager. 
createInstanceWithContext ('com.sun. 
star.bridge.UnoUrlResolver', uctx) 
ctx = resolv.resolve(‘uno: 
Socket, host—localhost, port—s000;urp;, 


StarOffice.ComponentContext ') 


n 

smgr - ctx.ServiceManager 

desktop - smgr.createInstance 
WithContext (‘com.sun.star.frame. 


Desktop”, Mee) 


n 
Inul = uno. 
systemPathToFileUrl (os.path. 
abspath (infile) ) 
doc = desktop. loadComponentFromU 


RIA Unc eU DS E 


# 

sheet = doc.getSheets(). 
getByIndex (0) 

al, = 0 

while True: 

a = Enes. 
getCellByPosition(0, i).getStrino(). 
S110) 

D = @lme@ . 


getCellByPosition(1, i).getString(). 


SErip () 
LE WOS A8 
break 
# 
14-- 1 
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# 

print a, by 

# 

q = “insert into test (1d, 


qty) values(‘%s’, $s)" Sla, b) 
param query’ | = q 
eparam = urllib. 

urlencode (param) 

Eres = urllis. 
urlopen('http://localhost:9000/ 
query', eparam) 

sres - fres.read() 

Ey. 

res - yaml.load(sres) 
except 


res - None 


u 

if res and res[0] >= 0: 
prints oh? 

Sees 


print "ftarled! 


# 


doc.close (True) 


return True 


try: ! ! 

1a gys. awa epus [il] I 
except IndexError: 

print “Usage: ss <input ` 


$ (sys.argv[0]) 
eleme 
di Main aa 
ret - 0 
# 
sys.exit (ret) 
Untuk mencoba: 
€ Pastikanlah server OpenOffice.org 
telah dijalankan. 
€ Pastikanlah dboverhttp telah di- 
jalankan pada localhost port 9000, 
atau sesuaikanlah parameter ko- 
neksi. 


Berikanlah perintah berikut untuk 
mendapatkan data dari spreadsheet 
dan menyimpannya ke database: 

«PREFIX OOO»/program/python 


sSpreadsihneer Gilo jou <o > 
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$ /opt/openoffice.org2.3/program/ 
python spreadsheet db.py a.ods 
AI AO) @l< 

A02 20 ok 

A03 40 ok 

A04 70 ok 


Ekspor Data dari MySQL ke 
opreadsheet 

Data dari spreadsheet telah tersim- 
pan di MySQL. Berikutnya, kita akan 
mengekspor dan menyimpannya ke 
spreadsheet. 

Program berikut, db spreadsheet. 
py, merupakan kombinasi dari con- 
toh tulisan otomatisasi OpenOffice. 
org di edisi 07/2010 (create-ods.py) 
dan sample-client-dboverhttp.py 
(contoh client dboverhttp). Pastikan 
modul PyYAML telah terinstal. 


Berikut adalah source code db 


spreadsheet.py: 


#(c) Noprianto, GPL 


import sys 
import os 
Impese urllib 


import yaml 


DATA CENTER : INDONESIA - SINGAPORE - CHINA - GERMANY - USA - AUSTRALIA 


INI 


E 

TY 8 
Import Uno 

SAS ie Ill Sona ons @s 
print e 


sys.exit (2) 


“db mv see 
‘est’ s “localhost” ; 
HINAR 20, 

user’ ‘spreadsheet’, 
‘pw’ : ‘password’, 
“elg” : “spreadsheet', 
unen m: p. 


) 


def main(outfile): 


u 
q = "select * from test’ 
param['query'] - q 


eparam - urllib.urlencode (param) 
thes = se] llah urlopen “heep3// 
localhost:9000/query’, eparam) 
sres = fres.read() 
ey 
res = yaml.load(sres) 


eoe 


DAXA NETWORKS 





DEDICATED COLOCATION VPS HOSTING 


B/w Intl Up to : 
Bw IIX Up to : 
HDD 


POP3, E-mail, FTP 


Bw Inti Up to : 
AW IX Up to : 


"pa 


| CGI, SQI. and much | 


Bw Intl Up to: 25 
B/w IK Up to : 
Vi M HDD 


ON-LINE SUPPORT 





7 “http :Ifid.daxa.net - info@daxa.net (021) 9700 8000- 5022 6000- 526 8000| A 
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Ni AA | e Pastikanlah dboverhttp telah dija- 
—NW ^ CT lankan pada localhost port 9000, 
atau sesuaikanlah parameter ko- 
neksi. 





Berikanlah perintah berikut untuk 
mengekspor data MySQL ke spread- 








sheet: 
Project toole This is the Uno Project «PREFIX 000>/program/python db | 
—— Lead: ag Flamma CoLeed Santan Daun Spreadsheet.py «output» 
a Line rara “or Universal Hetwork Übjecta Uno it one of Fe napa pasig of [gar org 
© Donde a Š /opt /openoffice .org2. 3 /program/ 
m im A EE in e nni duum M python db spreadsheet.py /tmp/b.ods 
ae. The Uno mob in eqquntred sa deswibed bs Un Maa omm dmn ID ge noc M qi 
Tpi Patah mar tanen iS CR paespia Seu ans ee ruari dong n Wine whet pru can teed in Pe Un Da of ( vq UNUS qus 20) n ( vidik 
(S ——————— 'A03', ‘qty’: 40), ('id': "204, 
— wana Wa) ae DP ia 
— JOE d UNDO SCELTE 20) 
UND Project. Sales UNOS) Ney AMI shes 
res = None = = ri ici] AOA Gy s 70}, (acs Ug 
b = ri gps Mite s 10}, frids AO “aey: 
if not res[0] >= 0: # 20}, (alalis A031, Ses s 40}, 
return False sheet.getCellByPosition(0, iude tan 7 e eggs 
i) esetStringi ci iae] ) VADE ary s 10}, (“acs SAQ22. 
# sheet .getCel1ByPosition (1, Ne 20), fidis Moe E "aey s 
print res L) seestrang (rl aty ||) AO}, (alalis "A04, Nope 70) 
# A01 10 
# gpl A02 20 
uctx - uno.getComponentContext () # A03 40 
resolv = uctx.ServiceManager. pronta) 19 A04 70 
createInstanceWithContext ('com.sun. # A01 10 
Star.bridge.UnoUrlResolver', uctx) ctx.ServiceManager A02 20 
ctx = resolv.resolve( uno: A03 40 
socket host-local host, port—8000;urp; # A04 70 
StarOffice.ComponentContext ') doc.storeAsURL(outurl, ()) A01 10 
# A02 20 
# doc.close (True) A03 40 
smgr - ctx.ServiceManager A04 70 
desktop - smgr.createInstance Terum MEUS A01 10 
WithContext('com.sun.star.frame. A02 20 
Desktop", des) lE meme == ` maim ”g A03 40 
KAE = 1 A04 70 
# try: 
outurl - uno. o = sys.argv[1] Penjelasan: 
systemPathToFileUrl (os.path. except IndexError: @ Data tampak banyak karena se- 
abspath (outfile) ) prant “usages = soutput- ` belumnya telah dimasukkan ber- 
doc - desktop.loadComponent %(sys.argv [0] ) ulang-ulang. 
FromURL('private:factory/scalc', else: e Apabila diperlukan, bacalah tu- 
"ila WO 0) if main(o): lisan: Mengakses database MySQL 
ret - 0 lewat HTTP (di edisi ini), terutama 
# # pada contoh client. 
sheer = doe getsheets |). Sve exile (ret) e Apabila diperlukan, bacalah tu- 
getByIndex (0) Untuk mencoba: lisan otomatisasi OpenOffice.org 
i = O € Pastikanlah server OpenOffice.org di edisi 07/2010.8 
for r in res[1]: telah dijalankan. Noprianto [noprianto C) infolinux.co.id] 
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pd ACCOUNTING Server 


Ege Paket Software Accounting Lokal yang 100% memakai. 
A | teknologi Web Based 





Integrated, Pembelian, Produksi (Manufacturing), 
— Penjualan, Pajak (PPh, PPN), Multi Currency, Multi 
Warehouse, Meraca, Rugi Laba. 













e Unlimited User, Unlimited Cabang, REAL TIME! 
d Server Linux/Windows. Client Web Browser. 
V — Free SMS plugin dengan eSMSis. 
Heavy Duty SMS Ser Ver 5 
IS Server & Gateway 

eSMSis Ver. 2.1 Movie Puri for your Applications 
Tn É WEB BASED, Internet Ready 

» DU ie Support BULK SMS (sender Text) 

Easily connected to external database 


Lione GSM/CDMA Modems with Automatic Same Operators 


feria de Users Groups /SubGroups 
4 Multi Users, User Quota 
SMS to Email, Email to pss 

| PROVEN ! Used by Hundreds of Multinational Companies. 





Linuxindo 


Wisma SLIPI Suite #415 
E-mail Infogtinuxinda.com 
JH. Let end. 5 Parman, Kav 12. 

Jakarta 11480 


(021) 5362390 
www.Linuxindo.com 


Your Onestop RP US. XU: 6 

















lt Paket Lengkap, Ekonomis dan Professional termasuk Konsultasi, Ma tenar 

Training & Setup 

a at ac Sabon melalukan migrasi Unc untuk 

-perusahaan TBK/Multinasional 

| Hanya butuh waktu 2 - 5 minggu saja (20 Servers, 1000 Desktop Terminals !!) 

1 gunakan Linux Enterprise Bebas ! Tidak perlu bayar lisensi Linux 
- Enterprise tahunan. 

fg Spesialis Linux sehingga sudah sangat berpengalaman dalam melakukan migrasi 
Linux dengan cepat dan lancar tanpa menganggu proses bisnis sehari-hari. 


Jadi ANI LINUX dalan 2 Mindat Saj 
Paket A-Z Linux (PAKAZ) 
igi Linux Concept & Fundamental 


Linux System Administration 
| Linux Internet + Intranet Server 











(14 days @4 hours) 
Limited Seat - Small Class 








ie RAE 
| al rataan | 16 hours 
tacts from Global Address List E MS k 
| ver (4 days & 4 hours) 
hared Calendars : 1 
Mm Limited Seat !! 





| tore attachments online in a briefcase 










“Bulan Suci diisi dengan Ilmu TT 


Marhaban Yaa Ramadhan Marhaban Yaa pum Tarbiyah 





9 w. Singkat, Mudah, Bermanfaat 
@ Di Rancang untuk Pemula 


Membangun Web mudah untuk pemula 


PrestaShop 
Mudah Membangun Toko Online 


Linux 3 in 1 


Mudah memakai Linux untuk pemula 
(Instalasi, Desktop, Office Suite) - 


E-Commerce 
dengan 


lopor Training Linux & 
Open Source di Indonesia 
SINCE | 


Margonda Raya No. 522 Tel (021) 7874223, 7874234 Fax (021) 7874225 

B Jl, Cinere Raya Blok D No. 6 Tel. (021) 7545181, 71096406 Fax, (021) 7548254 
JAKSEL Jl. Mampang Prapatan Raya 17A Tel. (021) 7975295, 7947115 Fax (021) 7901993 
JAKBAR !l Taman Kebon Jeruk (Meruya Ilir), Ruko intercon Plaza Blok A Na. 3 

Tel. (021) 5846839, 5846340 Fax (021) 5845583 NEW 
JAKTIM JL Paus Raya No. 92F - Rawamangun Tel [021] 47884891 Fax (021) 47883282 
BEKASI Jl. A. Yari- Ruko Sentra Niaga Kalimalang 6.12 (Seberang hlamic Center/samping BCP) 

Tel. (02118853537, 23742542 Fax. (071) 6853537 
BALIKPAPAN K.A Yoni Na 17 (Samping Bank Mandiri) Tel. (0542) 422000 Fax (0547) 413680 


Lembaga Pendidikan & Pengembangan Profesi Terpadu 


| LP3T NURUL FIKRI 


IT Training - IT Education 


info@nu 


"rs 9 39 47 Ü 
(o2; 91: "i de 


4 3318 54 


LEAT. NE 


NurulFikri.com - 


SMS Only: 


rulfikri.com 0816 1314 00 








WORKSHOP OFFICE 


Kita dapat menambahkan fungsionalitas OpenOffice.org 
dengan Macro, yang dapat dibuat dengan berbagai bahasa 
pemrograman. Pada Workshop kali ini, kita akan memban- 
gun macro python yang akan mendapatkan output dari 
program fortune dan memasukkannya ke dokumen Writer 
aktif. 


Apabila diperlukan, bacalah terlebih dahulu Workshop 
Menambahkan macro python pada My Macros (edisi 
08/2009). Macro yang kita buat, pymacro-fortune.py akan 
disimpan pada My Macros. 


1 Masuklah pada direktori ~/.openoffice.org2/user/Scripts/ 
python dengan perintah berikut ini: 


$ cd -/.openoffice.org2/user/Scripts/python/ 





Pertama-tama, buatlah script 
dengan isi sebagai berikut: 


pymacro-fortune.py 


#(c) Noprianto, 2010 
#GPL 
amport OS 
det show Fortune e 
doc = XSCRIPTCONTEXT.getDocument () 
Text = COG, TET 
cursor = text.createTextCursor () 
# 
fortune = os.popen2('fortune') [1] .read() 
# 


text INSerEeString (cursor, fortune | 0) 


g exportedSceripts = (shows ote 





Pastikan fortune terinstal di sistem. Apabila tidak dite- 
mukan, tidak ada pesan kesalahan yang ditampilkan. 
Di sistem penulis: 
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Tampilkan Fortune di OpenOffice.org Writer 








$ type fortune 


fortune is /usr/games/fortune 


Jalankan OpenOffice.org Writer dan macro kini bisa 
diakses dari menu dialog Tools | Macros | Organize 
Macros | Python... Pada dialog yang tampil, pilihlah My 
Macros | pymacro-fortune | show fortune. Untuk men- 
jalankan, kliklah tombol Run. 








Select Ene library that contains Eher macro you wank Then select tis 
freno uror Set reru 


rar Macro nama 


+ ihoa Tortune 


— EU By Mana 


F = 





ane P =. ai. 





Penjelasan dari script pymacro-fortune.py adalah se- 
bagai berikut: 

@ Kita akan meng-export satu fungsi, yaitu show. for- 
tune: 


g exportedscripts = (show Fortune, ) 


€ Ambil teks dokumen aktif: 
doc = XSCRIPTCONTEXT.getDocument () 


text = doc. Text 


€ Buat kursor: 


cursor - text.createTextCursor() 


@ Jalankan fortune dengan os.popen2(): 


fortune = os.popen2( rortune')[1].read() 


Fungsi ini akan mengembalikan file object (child stdin, 
child stdout). Kita akan membaca child stdout. 


@ Tambahkan teks: 


text .IinsertSering (cursor, fortune , 0) 


Noprianto [noprianto C) infolinux.co.id] 
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Memiliki prinsip penjualan 
Memahami market teknologi & media 


Memiliki prinsip pemasaran 
Memahami market media cetak 


Min. S1 Desain Komunikasi Visual 
Memiliki cita rasa yang tinggi 


Memahami prinsip tata letak media cetak 
Cekatan 


Min. S1 Bahasa 
Teliti 
Paham istwilah teknologi komputer 


Computer freak 
Sistematis 
Mengikuti perkembangan hardware 


Tulis lamaran Anda secara meyakinkan 

dan singkat, mengenai (a) apa yang Anda 
ketahui tentang kami, (b) mengapa kami 
perlu memilih Anda dan (0) apa yang Anda 
harapkan dari kami jika terpilih, dalam sebuah 
e-mail dan kirim ke: 


recruit.pinpoint@gmail.com 


Khusus CD & LY lampir! e-mail tersebut dengan 
contoh hasil karya. Kode lamaran yang Anda 
minati wajib dicantumkan di SUBJECT e-mail. 
E-mail yang tidak memenuhi syarat tidak akan 


diproses. 








UNTUK SEMUA POSISI: 
Memiliki notebook pribadi 


Berpengalaman di bidang yang relevan 
Mampu bekerja sistem deadline. 








- Hobi menulis 
Segudang ide 
Mengikuti perkembangan komputer 


Menyenangi penelitian di bidang keamanan 
data dan virus komputer 


Menguasai pemrograman 
Akrab dengan internal system Windows 


Menguasai LAMP & Ajax 
Hobi mengoprek kode 


PINPOINT 
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WORKSHOP PROGRAMMING 
Serialisasi/Deserialisasi Objek dengan Pickle Se” 


Menggunakan modul pickle, serialisasi ataupun deseriali- 
sasi objek dapat dilakukan dengan mudah. 


1 pertama yang perlu dilakukan adalah proses 
import modul pickle: 


>>> Import pickle 


Selanjutnya, kita akan bekerja dengan objek sebagai 
berikut: 


>>> a= { 
mame” s “python”; 
M Yversion sou. 
SSS (el 
('version': '2.x', ‘name’: ‘python’ | 


Pada tahap selanjutnya, kita dapat melakukan seriali- 
si untuk variabel a: 

>>> Ser = pickle.dumps (a) 

SSS Sig 

“(dp0\nS’ version’ \np1\nS’ 2.x’ \np2\nsS’ name’ \np3\ 

nS’ python’ \np4\ns.. ” 


Apabila apabila ingin langsung disimpan ke file, kita 
bisa gunakan fungsi dump(): 





Menggunakan class StringlO milik modul StringlO, kita 
bisa bekerja dengan string layaknya sebuah file. 


Tahap pertama yang perlu Anda lakukan adalah 
melakukan proses import modul StringIO: 


>>> Import St gp 


Selanjutnya, kita akan membuat sebuah file memory 
Q ane kosong: 

>>> © = Sera Oo Stringio() 

Spo i 

“StLingdlO,stringlO Instance at Oxe/bddied-= 

>>> Gai e) 


Lanjutkan dengan menambahkan string ‘halo apa 
kabar’ ke dalamnya: 


>>> f.write('halo apa kabar’ ) 


am kita baca isi file tersebut, dengan method 
getvalue(): 


>>> f.getvalue() 
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>>> pickle.dump(a, open('/tmp/ser', ‘w’) ) 
>>> open('/tmp/ser').read() 
“(dp0\nS’ version” \npl \nS’ 2.x" \np2 \nsS’ name” \np3 \ 


Hs’ python’ wp ug 


Setelah mengetahui contoh serialisasi, berikut contoh 
dari deserialisasi: 
>>> b = pickle. loads (ser) 
>>> l9 
('version': DI, DEMS” g toyta” | 
So, Joh == =: 
True 
Atau, apabila hasil serialisasi sebelumnya disimpan di 
file: 
>>> C = pickle.load(open("'/tmp/ser')) 
Dp» € 
('version': Lacs name: “py chon’ | 
Kita bisa juga menguraikan dengan bantuan modul 
d 
>>> Import pickletools 


>>> pickletools.dis (ser) 


highest protocol among opcodes = 0 


Noprianto [noprianto@infolinux.co.id] 


p 


Memory File dengan Modul Stringl0 Doa 


sa 


Abia anganan 


'halo apa kabar' 


Kita bisa juga mendapatkan isi file dengan method 
do Hanya, pastikan posisi file tidak EOF: 
€ Posisi (dalam contoh ini, ada di akhir karena sama 
dengan panjang file): 
>>> IE .]998 
14 
@ Kita pindahkan ke awal file: 
>>> f.seek(0) 
>>> Dos 
0 
@ Barulah kita gunakan method read(): 
>>> f.read() 
'halo apa kabar' 
€ Posisi file kembali ke EOF: 
>>> £ pos 
14 
>>> f-read() 


N 


Noprianto [noprianto C) infolinux.co.id] 
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Parsing URL dengan Modul urlparse 


Menggunakan modul urlparse, kita dengan mudah dapat 
memecah (dan menggabungkan kembali) suatu URL. 


1 Sebelum dapat melakukan parsing url, lakukan proses 
import modul urlparse: 


>>> import urlparse 


Kita akan gunakan contoh URL berikut: http://domain. 
tid:12345/-user/test/download?id-1234&mode-1ta1: 
>>> Url = “Http: //domain. tld-12345/ -user/test/ download n 

d=1234&mode=l1#al’ 


>>> Dp = Urlparse urliparse (url) 


>>> Jð 
(Mania, “domain, tles 12345/, usen test /download’) “7; 
“Id=1234e¢mode=1' Nad) 





>>> pdl -Path 

(“/-user/test/download', ‘/~user/test/download’ ) 
>>> PSl; -Pareng 

rc) 

>>> p[4], p.query 

('id-1234&mode-1', "id-1234&mode-1') 

sos 95] poctragment 

Gal ad?) 


Untuk mendapatkan host dan port: 
==>) Pp e Sanan 
“domain tld 
522p sport 
12345 


Hasil parsing bisa digabungkan kembali dengan urlun- 


Bagi pengguna python 2.5 atau yang lebih baru, selain n ema 


indeks integer, kita bisa gunakan atribut-atribut berikut: 
>>> p[0], p.scheme 
(unt pA “neto ) 
>>> DLL, ep netloe 


(“domain tid:]2345' domam tco 325) 


Teknik Membaca Output stdin 


Pada artikel kali ini, kita akan membahas contoh-contoh 
membaca dari stdin. 


Contoh di dalam tulisan ini dapat dijalankan dengan 

dua pola: 

Menggunakan pipe, dimana output dari program lain 
akan menjadi input untuk kita. Contoh: 


ls | «program» 


Tanpa menggunakan pipe. Untuk input, akan kita 
ketikkan sendiri, dan diakhiri dengan Ctrl-d. Contoh: 
«program» 
baris 1 
baris 2 


cCtrl-d untuk mengakhiri- 


Dalam contoh pertama, 1.py, apa yang kita lakukan 
Ê adalah membaca dari stdin dan mencetak ke stdout. 
import sys 
if name == °` mam 


sys.stdout.write(sys.stdin.read() ) 


Contoh: 
$ echo halo apa kabar | python 1.py 
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>>> url» = urlparse.urlunparse(p) 
>>> Wela 
‘http: //domain.t1d:12345/~user/test/download?id=1234&mo 
de-l#al' 
Noprianto (noprianto@infolinux.co.id | 


\ 





halo apa kabar 


$ python I py 
halo 

apa 

kabar 

<Tekan Ctrl-d> 


Dalam contoh kedua, 2.py, program akan menjumlah- 
kan bilangan-bilangan yang dilewatkan ke stdin. 
import sys 
acs 
# Source code 2.py selengkapnya dapat ditemukan 
# dalam ekstra DVD InfoLINUX edisi ini. 
| m 
prine coral 


Contoh: 
$ python 299 


«Tekan Ctrl-d» 
6 
Noprianto (noprianto@infolinux.co.id| 
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WORKSHOP DISTRO 


Qimo adalah distro Linux turunan Ubuntu/Xubuntu 
dengan desktop XFCE, yang ditujukan untuk pendidikan 
dan permainan anak-anak. Oimo juga dapat dikonfigurasi 
untuk perkantoran dan multimedia. 


Sebelum menggunakan @imo 2.0 secara live dari CD/ 
DVD/flash disk atau menginstalnya ke harddisk, Anda 
harus membakar file gimo-2.0-desktop.iso ke CD/ 
DVD. Jika tidak memiliki drive CD/DVD, Anda dapat 
memindahkan file iso Qimo itu ke flash disk dengan ban- 
tuan program Unetbootin di Linux/Windows atau Disk 
Imager di Windows (win32diskimager) atau yang sejenis. 

Secara default (bawaan) @imo 2.0 telah dilengkapi 
beberapa program untuk pendidikan dan permainan 
yang sangat cocok untuk anak usia pendidikan TK hingga 
SD. Namun, Qimo belum dilengkapi OpenOffice yang 
dibutuhkan untuk pendidikan sesuai kurikulum nasional 
mata pelajaran TIK (Teknologi Informasi dan Komunika- 
si). @imo juga belum mendukung file multimedia populer 
yang tidak open source, seperti mp3, mp4, guicktime, 
VCD/DVD, dan flash (flv). Workshop ini ditulis untuk 
mengatasi kekurangan itu. 


Boot dan Instal Qimo 

Saat CD atau flash disk yang telah berisi Qimo digunakan 
untuk booting komputer, halaman pertama akan mena- 
nyakan kepada Anda untuk memilih bahasa. Tekan Enter 
atau pilih bahasa bawaan, yaitu English. Anda juga 
dapat memilih bahasa Indonesia. Tunggu beberapa saat, 
sehingga muncul desktop @imo seperti di Gambar 1. 


e p inod 





¿Sy q ç C 


Untuk menginstal Qimo ke harddisk, klik Menu | Set- 
tings | Install RELEASE. Langkah selanjutnya seperti dis- 
tro Ubuntu 10.04 yang pernah dibahas pada edisi 06/2010. 
salah satu langkah yang penting dan perlu berhati-hati 
adalah saat akan membuat atau mengedit partisi. Secara 
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Qimo, Distro Linux untuk Anak-anak 







default, Qimo akan menghapus semua partisi (Erase 
and user en- m 

tire disk). Jika 
tidak ingin 
menghapus 
seluruh data 
di harddisk, 


Prepare dak apace 


Tha E u= pone Fi rk eee Ben ing Wi on à 


PA Le eee (eee) eee eee, XP Hosa E rh a: 
T3 UN rü NE LM 


=== — 
wig S qus au D pas Dea P OU 
rune ered uu the erties rio 


Anda harus 

ubah dengan 

memilih cara 
manual (Spe- grand, metik matar ines 


cify partitions 
manually), 
seperti Gambar 2. 


db bese’ 


Modifikasi Desktop 

Desktop XFCE bawaan @imo memiliki kelebihan dari 
sisi kesederhanaan dan kecepatan. Untuk mengakses pro- 
gram-program pendidikan dan permainan anak-anak, di 
bagian bawah desktop @imo ditambahkan beberapa icon 
pada suatu panel yang disebut Launcher. Jika layar moni- 
tor komputer Anda kecil, misalnya untuk resolusi layar 
1024 x 768, maka panel di bawah itu terlalu besar sehing- 
ga mengganggu karena mengurangi layar untuk bekerja. 
@ Cara mengecilkan panel, klik kanan salah satu icon, 

lalu pilih Customize Panel. 














€ Pada jendela L 
Panel seperti | m Cotten ia per re 
Gambar 3, ge- 


ser pengubah | ”' Ole 
ukuran atau 
Size (Pixels) ke 
kiri, sehingga 
mencapai ang- 
ka di bawah | 
30 atau sesuai | 
selera Anda. 

@ Anda juga dapat membuat hilang dan muncul secara 
otomatis dengan memilih Autohide. 


Program untuk Anak-anak 

Berikut ini penjelasan tujuh program di panel bawah, 

yang dibuat khusus untuk pendidikan anak-anak. 

@ Icon paling kiri untuk menjalankan editor teks seder- 
hana Mousepad, yang mirip Notepad di Windows. 

@ Icon kedua dari kiri untuk menjalankan gCompris, 
program pendidikan dan permainan (Edutainment) 
dari tingkat TK hingga kelas 6 SD atau yang setara, 
mulai dari mengenal huruf atau membaca, berhitung 
atau matematika, ilmu alam, hingga merangkai listrik, 
dan lain-lain. 
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€ Icon ketiga dari kiri untuk menjalankan Child's Play, 
program pendidikan dan permainan untuk anak-anak, 
mirip tapi lebih sederhana dari gCompris. 

€ Icon keempat dari kiri untuk menjalankan Tux Paint, 
program untuk menggambar bebas seperti MS Paint. 

€ Icon kelima dari kiri untuk menjalankan Tux Math, 
program untuk bermain sambil belajar matematika 
mulai dari dasar seperti penjumlahan, hingga tingkat 
atas seperti pecahan dan fraksi. 

€ Icon keenam dari kiri untuk menjalankan Tux Type, 
program untuk belajar mengetik dengan sepuluh jari. 

€ Icon ketujuh dari kiri untuk menjalankan Laby, rogram 
untuk belajar bahasa pemrograman dengan gambar 
semut dan sarang laba-laba. 


Mengakses Media Penyimpanan 
Perbedaan desktop XFCE Qimo ini dibandingkan desk- 
top GNOME dan KDE adalah dalam pengaksesan 
atau mount/umount partisi harddisk, flash disk, folder 
jaringan, dan tempat penyimpanan data lainnya. File 
manager yang dimiliki Qimo tidak langsung dapat me- 
nyambungkan (mount) media-media penyimpanan itu. 
Sebagai gantinya, tersedia program bernama Gigolo seb- 
agai penyambung media penyimpanan, dan Thunar seba- 
gai file manager. 
€ Untuk mengakses flash disk yang baru Anda colokkan, 
lebih dulu jalankan pengaksesnya melalui Menu | Sys- 
tem | Gigolo. Lalu jalankan pembuka isinya melalui 
Menu | File Manager. 


ai rumbo: Fam agan | 2304 





@ Pilih partisi atau nama media penyimpanan yang akan 
dibuka, misalnya dalam contoh ini ada partisi hard- 
disk yang diberi nama “data”. Klik icon data, lalu klik 
kanan dan pilih Connect. Setelah berhasil disambung- 
kan, icon data akan muncul di jendela file manager 
Thunar, sehingga Anda bisa mengakses baca atau tulis 
sesuai izin akses yang tersedia. 


O Mem aw jig W. = ud 


am 
Fw [prb Wee Score Pa 
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@ Sebelum Anda mencabut flash disk atau media penyim- 
panan lainnya, kembali klik kanan icon-nya di jendela 
Gigolo, lalu pilih Disconnect. Perintah Connect dan 
Disconnect juga dapat dijalankan melalui menu 
Actions | Connect/Disconnect, atau klik icon yang 
tersedia. 


Menginstal OpenOffice 

Jika Anda memiliki akses ke Internet yang baik (cepat 

dan murah), Anda dapat menginstal tambahan program, 

misalnya OpenOffice, melalui Synaptic Package Mana- 
ger. @imo 2.0 menggunakan server repository di Internet, 

sama dengan yang digunakan Ubuntu 10.04. 

Jika akses Internet Anda lambat atau tarifnya mahal, 
gunakan OpenOffice yang tersedia di DVD InfoLINUX. 
Contoh ini untuk menginstal OpenOffice versi 3.2 yang 
berbentuk tarball (OOo 3.2.0 LinuxIntel install wJRE . 
en-US deb.tar.gz). 
€ Ekstrak file tarball OpenOffice ke suatu direktori. 

@ Dari terminal (Menu | Terminal), berubah jadi root 
dengan perintah “sudo su”. 

@ Lalu, pindah ke direktori hasil ekstrak dengan perin- 
tah “cd 000320 m12 native packed-1 en-US.9483/ 
DEBS”. 

€ Jalankan perintah “sudo dpkg -i *.deb" untuk mengins- 
tal semua paket OpenOffice. 

@ Pindah ke direktori desktop-integration, lalu jalankan 

kembali perintah “sudo dpkg -i *.deb" untuk mengins- 

tal program yang mengatur menu OpenOffice di desk- 
top Qimo. 





Ü Men. | mb Terminal -rootfeusda | 
B p e uL ee ELI] 
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Menginstal Paket untuk Multimedia 

Jika tidak tahu paket apa yang harus diinstal lebih dahulu, 
Anda dapat menggunakan program pemutar multimedia 
dari Menu | Multimedia | Movie Player untuk membuka 
file-file multimedia, seperti mp3, mp4, dan flv, lalu ikuti 
langkah selanjutnya. Syaratnya, Anda punya koneksi 
Internet yang baik. 

Jika tidak punya koneksi Internet yang baik, Anda 
dapat menggunakan kumpulan paket extras untuk Qimo 
atau repository Ubuntu 10.04, yang juga disertakan 
dalam DVD edisi 08/2010 ini. Tambahkan repository itu 
melalui menu Synaptic Package Manager, klik Settings | 
Repositories | Other Softwares, lalu tambahkan alamat 
folder yang berisi repository, misalnya “deb file:/data/ex- 
tras qimo/”. Setelah disimpan, klik Reload untuk meng- 
aktifkannya. 

Cara lain lagi adalah menginstal semua paket yang 
ada di DVD dalam direktori extras khusus untuk Qimo, 
dengan perintah “dpkg -i *.deb” di terminal. 

Rusmanto [rus@infolinux.co.id] 
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di bawah ini. 










Garanya: 


Di antara susunan huruf dalam kotak di atas, tersembunyi beberapa nama distro Linux. Arah tulisan bisa berupa horisontal, vertikal, maupun 
diagonal, dengan arah membaca bisa dari kiri ke kanan, kanan ke kiri, atas ke bawah, atau bawah ke atas. 






Termasuk dalam kategori apakah beragam paket aplikasi yang tersembunyi pada gambar di atas? 
A. Wiki B. Groupware C. CCTV System 















Kirimkan jawaban Anda melalui SMS (Short Message Service) dengan format: LINUX<spasi>08<spasi>[Jawaban A/B/C] «spasi» Nama 


Contohnya: LINUX 08 A Budi Santosa SHB qoos nix 
Kirim jawaban tersebut melalui SMS ke 7669 (tarif Rp2000----/SMS berlaku untuk semua operator). sa ne fren ra 


Atau melalui kartu pos, yang dilengkapi kupon kuis yang terdapat di halaman ini, ke Kuis InfoLINUX, Jl. Kramat IV No. 11, Jakarta, 10430. 


SMS atau Kartu Pos diterima paling lambat 20 Agustus 2010. Daftar pemenang akan kami umumkan pada InfoLINUX No. 10/2010. 





Para pemenang harap menghubungi Sekretariat Redaksi /nfoL/NUX melalui telepon (021) 315-3731 ext. 127 atau e-mail ke evawani. putri@infolinux. 
co.id untuk verifikasi (tanpa verifikasi dan pengambilan hadiah hingga dua bulan semenjak pengumuman ini, hadiah dinyatakan hangus). Setelah 
verifikasi berhasil, pemenang yang berdomisili di Jabodetabek bisa mengambil hadiah di kantor Redaksi /nfoLINUX setiap hari/jam kerja, Senin- 
Jumat, 9.30-16.30 WIB, dengan menyerahkan identitas diri yang masih berlaku. Hadiah bagi pemenang di luar Jabodetabek akan dikirim via pos 
(ongkos ditanggung pemenang). InfoLINUX tidak bertanggung jawab atas kerusakan atau kehilangan hadiah yang terjadi selama pengiriman. 


64 08/2010 m INFOLINUX www. .infolinux.web.id 


berlangganan hemat 


DENGAN DVO B GB 


r 


COMMUMIEATE, COLLARORATE, LD SHARE 


ONLINE GROUPWAR 






:LINUX k: 


SRG Ee, STR bE PET, hil kë H E š 





E 


gera ASO aji nra tpps uB'rips uiuit 


pas perkantoran yang bèrs daiam Gro buts 


Meeko 1.Ú ` 


für =s 
Netbook 


ee INSIDE Ovo 








— WN B š lÍ Berk www manra: um 
=== 


LEE iraga ar maran ar 
TOU! oe masa tuan ee mamas. 
= | MÉLLU eee en 

r rg Se 

ki LE wa-asz es: —masa, 


Hubungi: 
— Teknik Pembuatan 
Otentikasi Sguid 





Telp: (021) 4682-6816, 7079-6499 
Fax: (021) 4682-8919 
e-mail: sirkulasi@pcmedia.co.id 
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FORMULIR BERLANGGANAN 


DATA PRIBADI 
(Pilih dengan tanda V dan isi dengan huruf kapital) 


[v] Saya ingin berlangganan majalah InfoLINU X: 


NO. | WILAYAH PAKET HARGA 
LANGGANAN LANGGANAN 


. | Jabodetabek O 6 Bulan (6 Edisi) Rp229.500 
Q 1 Tahun (12 Edisi) Rp432.000 
Pulau Jawa O 6 Bulan (6 Edisi) Rp240.000 
(Jateng, Jabar, Jatim) Q 1 Tahun (12 Edisi) Rp450.000 
3. | Bali/Sumbar Q 1 Tahun (12 Edisi) Rp540.000 
4. | Sumut/Kalimantan/Sulawesi Q 1 Tahun (12 Edisi) Rp558.000 
. | Indonesia Timur O 1 Tahun (12 Edisi) Rp558.000 
Nama Lengkap: 
Alamat: 
Kode Pos: 
Telepon: Fax: 
Mobile/ E-mail: 
Mulai berlangganan Edisi: 
Cara Pembayaran: 
Transfer ke BCA Cabang Raden Saleh 
a/n PT DIAN PASIFIK KOMUNIKASI UTAMA 
No. Rekening 634 018 0079 
mI aa C "D lánggal: — 


, Bukti transfer & formulirini | 
| harap di-fax ke (021) 4682-8919 | 
l ° | 
|. Up. Bagian Langganan |, 


Sirkulasi Pinpoint Publications (DPKU) 





MAKIN DEKAT 
DENGAN ANDA 


LUAR JAWA Medan: Pustaka Obor 
061-4145622 * Pekanbaru: Jack 0761- 
27706 e Padang: Taman Bacaan 0751- 
35150 e Palembang: TB Sriwijaya 0711- 
320679 e Jambi: Gloria 0741-23360, 
Elieson 0741-24424 e Bengkulu: TB 
Zaldy 0736-24291 e Pangkal Pinang: 
Supermini 0717-423973, Idris Hadi 0717- 
424547 e Tanjungkarang: Tohoma 0721- 
261839, Intisari 0721-64026 * Pontianak: 
Angkasajaya 0561-734689, Ridho 0561- 
7/5843 * Balikpapan: TBTerang 0542- 
421301, Antra 0542-396003 e Samarinda: 
Aziz 0541-260235, A.Terang 0541-741768 
e Banjarmasin: Naprin Budhi 0511-65475 
e Palangakaraya: Fathir 0536-28317 e 
Makasar: Telly 0411-321795, IndahJaya 
0411-330707 * Kendari: TB Ade 0401- 
21613 * Palu: Ramedia 0451-421218, 
Masrun 0451-423805 e Manado: Lok 
Book Store 0431-852734 * Denpasar: 
Corsica 0361-226358, TB Anna 0361- 
427594, Gunung Agung dan Gramedia » 
Mataram: Titian 0370-622188 e Kupang: 
Rapi 0380-832033 


PULAU JAWA Cilegon: Torpedo 
Agc 0254-391460 * Serang: Estica Agc 
0254-202292 e Bandung: Alphabet Agc 
022-6006000, Gunaraya 022-4232513, 
Wahyudin Agc 022-6011414 e Garut: 
Monita Agc 0262-23479 e Tasikmalaya: 
Nasuha 0265-334064 * Indramayu: 
Kompas Agc 0234-484032 * Cirebon: 
Cirebon Agc 0231-203376 * Tegal: Tegal 
News Agc 0283-356138 e Pekalongan: 
TB Rajamurah 285- 424463, Fajar Agc 
0285-431466 * Semarang: Erlangga Agc 
024 -8313405, Hartono Agc 024-3545301, 
Adila Agc 024-3560615, Hariani Agc 024- 
3541832, TB Prasojo 024-569561 * Solo: 
TB ABC 0271-644345, Sendang Mulia Agc 
0271-633751 * Yogyakarta: Hidup Agc 
0274-587921-Lamhaba 0274-541808, 
Togamas, dan Gramedia e Magelang: TB 
Larista 0293-368060 * Purwokerto: TB 
ABC 0281-638344, SHS Agc 0281-622485 
e Surabaya: Kantor Perwakilan 031- 
8291511, Gunung Agung dan Gramedia e 
Malang: Yahya Oentoeng 0341-3410105 
e Kediri: TB Alief 0354-684211 * Jember: 
TB Amanah, Gunung Agung 


TOKO BUKU JABOTABEK 
Maruzen: Blok M 7268334, Sultan 
Agung 8307641 * Kharisma: Cijantung 
87793375, Cinere 7534125, Cilandak 
18840163, Taman Anggrek 5639343, 
Puri 5822629, Pamulang 7445019 
Kalimalang 8601887, Klender 86605956 
e Gramedia: Matraman 8581763, Pondok 
Indah 7506997, Pintu Air 3843800, 
Melawai 7203445, Gajahmada 2601234, 
Citraland 5606363, Pluit 6683620, Cinere 
7540663, Bekasi 8840401, Bogor 0251- 
356341 e° Gunung Agung: Pondok Indah 
1506901, Taman Anggrek 5639045, 
Citraland 5681512, Kwitang 3102004, 
Blok M 7209344, Arion 7413078, Atrium 
3867831, Lokasari 6254730, Bogor 0251- 
326876 e News Stand Niaga Tower 
2505250 e Time PI 330434 e Newstand 
WTC Sudirman 5211216, Mandarin 
5678888 e Trio 7982331 e JBC Kalibata 
7970350 e CabangTB Utama 
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EDISI MENDATA 


Cwikter 





Aplikasi Pendidikan Online 


Dalam kegiatan proses belajar-mengajar secara online, 
dibutuhkan tools e-learning yang baik. Pada edisi depan, 
akan dijelaskan penggunaan BigBlueButton yang dapat 
mempermudah kegiatan belajar-mengajar secara online. 
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Makin Asyik 
Ber-Iwitter Ria 





Audit Akses File di Samba 


Suatu saat, file penting yang terdapat di server Samba 
terhapus, namun Anda sulit mengetahui siapa user yang 
menghapusnya. Untuk menghindari hal ini, gunakan fitur 
audit akses file/direktori pada server Samba. 






































Beragam Format Serialisasi Data 
Beragam format serialisasi data populer, termasuk 
JSON, YAML, dan yang lain, sudah tersedia di Linux. 
Selain itu, edisi depan juga membahas dukungan format 
serialisasi data untuk beragam bahasa pemrograman. 





Topik-topik pada edisi mendatang masih mungkin berubah. 


INFOLINUX 





Ekspor Data MySQL ke PDF 


Memiliki tabel dalam database MySQL dan ingin 
mengekspor ke PDF? Mudah saja, jika sudah menge- 
tahui tekniknya. Ingin mengetahui tekniknya? Tunggu 
penjelasannya di InfoLINUX edisi mendatang. 


www .infolinux.web.id 





MAJALAH 
EXTRA 
SPEGIAL 


PCMEDIA GROUP 


untuk para pengguna 
PC dengan beragam 
tema dan tutorial 
konkret plus CD/DVD. 





PC MILD EXTRA 02 
Meningkatkan performa 
dan kinerja komputer. 
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PC MILD EXTRA 03 
Meningkatkan performa 
dan kinerja komputer. 


Untuk pemesanan langsung hubungi: 
Sirkulasi Pinpoint Publications (DPKU) 











PCMEDIA SPECIAL 02 


Office 2010 Beta plus trik 
dan tutorial komplet. 


PCMEDIA EXTRA 01 
Cara memroteksi 
komputer Windows XP. 





PCMEDIA EXTRA 02 
Mengupas sistem operasi 
Windows 7 secara detail. 


Telp: (021) 4682-6816, 7079-6499. Fax: (021) 4682-8919 sirkulasi@pcmedia.co.id 
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PCMEDIA SPECIAL 03 
Panduan, tes, dan tip&trik 
ponsel BlackBerry. 


INFO LINUX EXTRA 02 
Memahami distro Linux 
Ubuntu dengan mudah. 


INFO LINUX EXTRA 03 
Memanipulasi foto dan 
gambar dengan GIMP. 





& 





er 


MORE POWER MORE PROFIT 








Rainer SV110C4-2.4 SATA35NR 


Intel Xeon X3430 2.4 GHz 8 MB L3 Cache 
(4 Cores Nehalem) 
Intel S3420GP Server Chipset 
2x Intl Gigabit Ethernet 10/100/10 
Visipro 1 GB DDR3 ECC 
Seagate Barracuda ES 250 GB SATAII 32 MB cache 24/7 
Tower Chassis 350 Watt Active PFC 


Rp 6.900.000,-* 


"Server Rainer 4 Core Xeon teknologi Nehalem dengan motherboard & chipset 

Intel memang Dahsyat! Dengan harga sama dengan laptop Core Duo 
mempunyai performance hampir empat kali lipat! Dengan UnixBench 5.2.1 
e Rainer 4 Core Xeon memperoleh Final Score 2871.5, Sementara Laptop 
- dengan Processor Core Duo memperoleh Final Score 745.2. 


Cool Banget! Rainer Server memang lebih keren!” 
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perusahaan Anda begitu EKSIS 3 
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Powerful. 


www.raingrserver.net/ dealer Intelligent. 


*Harga sudah termasuk PPN dan FOB Jakarta 





